2 Star 15 Fork 17

王布衣/engine

加入 Gitee
与超过 1400万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
scheduler.go 1.58 KB
一键复制 编辑 原始数据 按行查看 历史
package services
import (
"errors"
"fmt"
"gitee.com/quant1x/gox/coroutine"
"gitee.com/quant1x/gox/cron"
"gitee.com/quant1x/gox/logger"
"strings"
"sync"
)
// Task 定时任务
//
// 默认每10秒检测1次
// 排名不分先后
type Task struct {
name string
spec string
Service func()
}
var (
ErrAlreadyExists = errors.New("job is already exists")
)
var (
jobMutex sync.Mutex
mapJobs = map[string]Task{}
crontab = cron.New()
)
// Register 注册定时任务
func Register(name, spec string, callback func()) error {
jobMutex.Lock()
defer jobMutex.Unlock()
_, ok := mapJobs[name]
if ok {
return ErrAlreadyExists
}
if len(spec) == 0 {
spec = cronDefaultInterval
}
job := Task{name: name, spec: spec, Service: callback}
mapJobs[job.name] = job
return nil
}
// DaemonService 守护进程服务入口
func DaemonService() {
jobMutex.Lock()
// 启动服务
logger.Infof("启动定时任务列表")
crontab.Start()
// 输出2个空白行
fmt.Printf("%s", strings.Repeat("\n", 2))
for _, v := range mapJobs {
message := fmt.Sprintf("Service: %s, Interval: %s, ", v.name, v.spec)
logger.Info(message)
_, err := crontab.AddJobWithSkipIfStillRunning(v.spec, v.Service)
if err != nil {
logger.Infof(message+"failed, err: %s", err.Error())
} else {
logger.Infof(message + "success")
}
}
jobMutex.Unlock()
// 等待结束
coroutine.WaitForShutdown()
// 关闭任务调度
crontab.Stop()
}
func PrintJobList() {
for _, v := range mapJobs {
spec := v.spec
message := fmt.Sprintf("Service: %s, Interval: %s", v.name, spec)
fmt.Println(message)
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/quant1x/engine.git
git@gitee.com:quant1x/engine.git
quant1x
engine
engine
v0.6.7

搜索帮助