You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
gojobs/run.go

108 lines
3.3 KiB

2 years ago
package gojobs
import (
"context"
2 years ago
"go.dtapp.net/gojobs/jobs_gorm_model"
2 years ago
"go.dtapp.net/gotime"
2 years ago
"go.dtapp.net/gotrace_id"
2 years ago
)
// Run 运行
2 years ago
func (c *Client) Run(ctx context.Context, task jobs_gorm_model.Task, taskResultCode int, taskResultDesc string) {
2 years ago
runId := gotrace_id.GetTraceIdContext(ctx)
if runId == "" {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run]%s", "上下文没有跟踪编号")
return
}
2 years ago
c.gormClient.Db.Create(&jobs_gorm_model.TaskLog{
TaskId: task.Id,
TaskRunId: runId,
TaskResultCode: taskResultCode,
TaskResultDesc: taskResultDesc,
SystemHostName: c.config.systemHostName,
SystemInsideIp: c.config.systemInsideIp,
SystemOs: c.config.systemOs,
SystemArch: c.config.systemArch,
GoVersion: c.config.goVersion,
SdkVersion: c.config.sdkVersion,
SystemOutsideIp: c.config.systemOutsideIp,
})
switch taskResultCode {
case 0:
2 years ago
err := c.EditTask(c.gormClient.Db, task.Id).
2 years ago
Select("run_id", "result", "next_run_time").
2 years ago
Updates(jobs_gorm_model.Task{
2 years ago
RunId: runId,
2 years ago
Result: taskResultDesc,
NextRunTime: gotime.Current().AfterSeconds(task.Frequency).Time,
2 years ago
}).Error
if err != nil {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run.0]%s", err.Error())
2 years ago
}
return
case CodeSuccess:
2 years ago
// 执行成功
2 years ago
err := c.EditTask(c.gormClient.Db, task.Id).
2 years ago
Select("status_desc", "number", "run_id", "updated_ip", "result", "next_run_time").
2 years ago
Updates(jobs_gorm_model.Task{
2 years ago
StatusDesc: "执行成功",
2 years ago
Number: task.Number + 1,
2 years ago
RunId: runId,
UpdatedIp: c.config.systemOutsideIp,
2 years ago
Result: taskResultDesc,
NextRunTime: gotime.Current().AfterSeconds(task.Frequency).Time,
2 years ago
}).Error
if err != nil {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run.CodeSuccess]%s", err.Error())
2 years ago
}
case CodeEnd:
2 years ago
// 执行成功、提前结束
2 years ago
err := c.EditTask(c.gormClient.Db, task.Id).
2 years ago
Select("status", "status_desc", "number", "updated_ip", "result", "next_run_time").
2 years ago
Updates(jobs_gorm_model.Task{
2 years ago
Status: TASK_SUCCESS,
StatusDesc: "结束执行",
2 years ago
Number: task.Number + 1,
UpdatedIp: c.config.systemOutsideIp,
2 years ago
Result: taskResultDesc,
2 years ago
NextRunTime: gotime.Current().Time,
2 years ago
}).Error
if err != nil {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run.CodeEnd]%s", err.Error())
2 years ago
}
case CodeError:
2 years ago
// 执行失败
2 years ago
err := c.EditTask(c.gormClient.Db, task.Id).
2 years ago
Select("status_desc", "number", "run_id", "updated_ip", "result", "next_run_time").
2 years ago
Updates(jobs_gorm_model.Task{
2 years ago
StatusDesc: "执行失败",
2 years ago
Number: task.Number + 1,
2 years ago
RunId: runId,
UpdatedIp: c.config.systemOutsideIp,
2 years ago
Result: taskResultDesc,
NextRunTime: gotime.Current().AfterSeconds(task.Frequency).Time,
2 years ago
}).Error
if err != nil {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run.CodeError]%s", err.Error())
2 years ago
}
}
2 years ago
if task.MaxNumber != 0 {
if task.Number+1 >= task.MaxNumber {
2 years ago
// 关闭执行
2 years ago
err := c.EditTask(c.gormClient.Db, task.Id).
2 years ago
Select("status").
Updates(jobs_gorm_model.Task{
Status: TASK_TIMEOUT,
}).Error
if err != nil {
c.zapLog.WithTraceId(ctx).Sugar().Errorf("[gojobs.Run.TASK_TIMEOUT]%s", err.Error())
2 years ago
}
}
}
return
2 years ago
}