xxljob

package module
v1.0.2 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Aug 6, 2021 License: MIT Imports: 16 Imported by: 0

README

xxl-job-go-client

xxl-job 对应的golang客户端

提供Elasticsearch 日志组件,把job执行过程写入elasticsearch方便跟踪查询
 func main() {
    exec := xxl.NewExecutor(
    xxl.ServerAddr("http://192.168.1.50:8080/xxl-job-admin"),
    xxl.AccessToken(""), //请求令牌(默认为空)
    //xxl.ExecutorIp("xxl-job-executor-test"),    //可自动获取
    xxl.ExecutorPort("9999"),                     //默认9999(非必填)
    xxl.RegistryKey("golang-jobs"),               //执行器名称
    xxl.SetLogger(xxl.NewLogEs().InitEs([]string{"192.168.1.50:9200"}, "100058", "dev")), //自定义日志
    )
    exec.Init()
    //设置日志查看handler
    exec.LogHandler(xxl.EsLogHandler)
    //注册任务handler
    exec.RegTask("task.test", task.Test)
    exec.RegTask("task.test2", task.Test2)
    exec.RegTask("task.panic", task.Panic)
    log.Fatal(exec.Run())
}

Documentation

Index

Constants

View Source
const INDEX_KEY_PREFIX = "xxl-job-log-"
View Source
const SERVER_PORT string = "9999"

Variables

View Source
var (
	DefaultExecutorPort = "9999"
	DefaultRegistryKey  = "golang-jobs"
)

Functions

func Int64ToStr

func Int64ToStr(i int64) string

Int64ToStr int64 to str

Types

type EsClient

type EsClient struct {
	Servers []string //服务地址
	AppId   string   `json:"appId"` // 应用ID
	Env     string   `json:"env"`   // 运行环境
	// contains filtered or unexported fields
}

func (*EsClient) AddLog

func (e *EsClient) AddLog(logEs *LogEs) error

往es写日志

func (*EsClient) Connect added in v1.0.0

func (e *EsClient) Connect() error

连接ES

func (*EsClient) ReadLog

func (e *EsClient) ReadLog(logId int64, LogDateTime int64) ([]interface{}, error)

从es读日志 LogDateTime 到毫秒

type ExecuteResult

type ExecuteResult struct {
	Code int64       `json:"code"`
	Msg  interface{} `json:"msg"`
}

ExecuteResult 任务执行结果 200 表示任务执行正常,500表示失败

type Executor

type Executor interface {
	// Init 初始化
	Init(...Option)
	// LogHandler 日志查询
	LogHandler(handler LogHandler)
	// RegTask 注册任务
	RegTask(pattern string, task TaskFunc)
	// RunTask 运行任务
	RunTask(writer http.ResponseWriter, request *http.Request)
	// KillTask 杀死任务
	KillTask(writer http.ResponseWriter, request *http.Request)
	// TaskLog 任务日志
	TaskLog(writer http.ResponseWriter, request *http.Request)
	// 心跳检测
	Beat(writer http.ResponseWriter, request *http.Request)
	//空闲检测
	IdleBeat(writer http.ResponseWriter, request *http.Request)
	// Run 运行服务
	Run() error
	// Stop 停止服务
	Stop()
}

Executor 执行器

func NewExecutor

func NewExecutor(opts ...Option) Executor

NewExecutor 创建执行器

type LogEs

type LogEs struct {
	Contents []string    `json:"contents"` // 日志内容,主动记录
	LogId    int64       `json:"logId"`    // 日志ID
	Locker   *sync.Mutex `json:"-"`        // 加锁,防止日志覆盖
}

实现了Logger接口

func NewLogEs

func NewLogEs() *LogEs

func (*LogEs) Error

func (l *LogEs) Error(logId int64, format string, log ...interface{})

追加ERROR类型的Task Log

func (*LogEs) Flush

func (l *LogEs) Flush()

flush Log

func (*LogEs) Info

func (l *LogEs) Info(logId int64, format string, log ...interface{})

追加INFO 类型的Task Log

func (*LogEs) InitEs

func (l *LogEs) InitEs(servers []string, appId string, env string) *LogEs

初始化ES

type LogFunc

type LogFunc func(req LogReq, res *LogRes) []byte

LogFunc 应用日志

type LogHandler

type LogHandler func(req *LogReq) *LogRes

type LogReq

type LogReq struct {
	LogDateTim  int64 `json:"logDateTim"`  // 本次调度日志时间
	LogID       int64 `json:"logId"`       // 本次调度日志ID
	FromLineNum int   `json:"fromLineNum"` // 日志开始行号,滚动加载日志
}

LogReq 日志请求

type LogRes

type LogRes struct {
	Code    int64         `json:"code"`    // 200 表示正常、其他失败
	Msg     string        `json:"msg"`     // 错误提示消息
	Content LogResContent `json:"content"` // 日志响应内容
}

LogRes 日志响应

func EsLogHandler

func EsLogHandler(req *LogReq) *LogRes

es查询日志

type LogResContent

type LogResContent struct {
	FromLineNum int    `json:"fromLineNum"` // 本次请求,日志开始行数
	ToLineNum   int    `json:"toLineNum"`   // 本次请求,日志结束行号
	LogContent  string `json:"logContent"`  // 本次请求日志内容
	IsEnd       bool   `json:"isEnd"`       // 日志是否全部加载完
}

LogResContent 日志响应内容

type Logger

type Logger interface {
	Info(logId int64, format string, a ...interface{})
	Error(logId int64, format string, a ...interface{})
	Flush()
}

Logger 系统日志

type Option

type Option func(o *Options)

func AccessToken

func AccessToken(token string) Option

AccessToken 请求令牌

func ExecutorIp

func ExecutorIp(ip string) Option

ExecutorIp 设置执行器IP

func ExecutorPort

func ExecutorPort(port string) Option

ExecutorPort 设置执行器端口

func RegistryKey

func RegistryKey(registryKey string) Option

RegistryKey 设置执行器标识

func ServerAddr

func ServerAddr(addr string) Option

ServerAddr 设置调度中心地址

func SetLogger

func SetLogger(l Logger) Option

SetLogger 设置日志处理器

type Options

type Options struct {
	ServerAddr   string        `json:"server_addr"`   //调度中心地址
	AccessToken  string        `json:"access_token"`  //请求令牌
	Timeout      time.Duration `json:"timeout"`       //接口超时时间
	ExecutorIp   string        `json:"executor_ip"`   //本地(执行器)IP(可自行获取)
	ExecutorPort string        `json:"executor_port"` //本地(执行器)端口
	RegistryKey  string        `json:"registry_key"`  //执行器名称
	LogDir       string        `json:"log_dir"`       //日志目录
	// contains filtered or unexported fields
}

type Registry

type Registry struct {
	RegistryGroup string `json:"registryGroup"`
	RegistryKey   string `json:"registryKey"`
	RegistryValue string `json:"registryValue"`
}

Registry 注册参数

type RunReq

type RunReq struct {
	JobID                 int64  `json:"jobId"`                 // 任务ID
	ExecutorHandler       string `json:"executorHandler"`       // 任务标识
	ExecutorParams        string `json:"executorParams"`        // 任务参数
	ExecutorBlockStrategy string `json:"executorBlockStrategy"` // 任务阻塞策略
	ExecutorTimeout       int64  `json:"executorTimeout"`       // 任务超时时间,单位秒,大于零时生效
	LogID                 int64  `json:"logId"`                 // 本次调度日志ID
	LogDateTime           int64  `json:"logDateTime"`           // 本次调度日志时间
	GlueType              string `json:"glueType"`              // 任务模式,可选值参考 com.xxl.job.core.glue.GlueTypeEnum
	GlueSource            string `json:"glueSource"`            // GLUE脚本代码
	GlueUpdatetime        int64  `json:"glueUpdatetime"`        // GLUE脚本更新时间,用于判定脚本是否变更以及是否需要刷新
	BroadcastIndex        int64  `json:"broadcastIndex"`        // 分片参数:当前分片
	BroadcastTotal        int64  `json:"broadcastTotal"`        // 分片参数:总分片
}

RunReq 触发任务请求参数

type Task

type Task struct {
	Id    int64
	Name  string
	Ext   context.Context
	Param *RunReq

	Cancel    context.CancelFunc
	StartTime int64
	EndTime   int64

	LogId int64
	// contains filtered or unexported fields
}

Task 任务

func (*Task) Info

func (t *Task) Info() string

Info 任务信息

func (*Task) Run

func (t *Task) Run(callback func(code int64, msg string))

Run 运行任务

type TaskFunc

type TaskFunc func(cxt context.Context, param *RunReq, logger Logger) string

TaskFunc 任务执行函数

Directories

Path Synopsis

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL