123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- package internal
- import (
- "context"
- "encoding/json"
- "github.com/gogf/gf/container/gmap"
- "github.com/gogf/gf/encoding/gjson"
- "github.com/gogf/gf/v2/os/gcron"
- "sparrow/pkg/rule"
- "sparrow/pkg/server"
- )
- // TaskSchedule task schedule 任务调度
- type TaskSchedule struct {
- tasks *gmap.HashMap // 保存任务名称与任务实体的映射
- cron *gcron.Cron
- }
- func NewTaskSchedule() *TaskSchedule {
- return &TaskSchedule{
- tasks: gmap.NewHashMap(true),
- cron: gcron.New(),
- }
- }
- func (t *TaskSchedule) AddTask(msg []byte) error {
- var task rule.TimerTaskMessage
- err := json.Unmarshal([]byte(msg), &task)
- if err != nil {
- return err
- }
- // 如果已经存在相同任务Id
- if t.tasks.Contains(task.TaskId) {
- return nil
- }
- newJson := gjson.New(task.Actions)
- server.Log.Debugf("add task: taskId:%s,corn:%s,actions:%s", task.TaskId, task.Cron, newJson.MustToJsonString())
- // 创建任务
- entity, err := t.cron.AddTimes(context.Background(), task.Cron, task.Times, func(ctx context.Context) {
- if err = NewTaskExecutor(task.Actions).Do(); err != nil {
- server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
- }
- }, task.TaskId)
- if err != nil {
- return err
- }
- t.tasks.Set(task.TaskId, entity)
- server.Log.Debugf("add a new timer task :%s", task.TaskId)
- return nil
- }
- func (t *TaskSchedule) AddMessageHandle(msg *rule.TaskLifecycleMessage) error {
- return nil
- }
- func (t *TaskSchedule) RemoveMessageHandle(msg *rule.TaskLifecycleMessage) error {
- t.cron.Remove(msg.TaskId)
- _ = t.tasks.Remove(msg.TaskId)
- server.Log.Debugf("RemoveMessageHandle :%s", msg.TaskId)
- return nil
- }
- func (t *TaskSchedule) UpdateMessageHandle(msg *rule.TaskLifecycleMessage) error {
- t.cron.Remove(msg.TaskId)
- var task rule.TimerTaskMessage
- _ = json.Unmarshal([]byte(msg.Data), &task)
- entity, err := t.cron.Add(context.Background(), task.Cron, func(ctx context.Context) {
- if err := NewTaskExecutor(task.Actions).Do(); err != nil {
- server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
- }
- }, msg.TaskId)
- if err != nil {
- return err
- }
- t.tasks.Set(msg.TaskId, entity)
- server.Log.Debugf("UpdateMessageHandle :%s", msg.TaskId)
- return nil
- }
- func (t *TaskSchedule) SnapMessageHandle(msg *rule.TaskLifecycleMessage) error {
- t.cron.Stop(msg.TaskId)
- server.Log.Debugf("SnapMessageHandle :%s", msg.TaskId)
- return nil
- }
- func (t *TaskSchedule) StartMessageHandle(msg *rule.TaskLifecycleMessage) error {
- t.cron.Start(msg.TaskId)
- server.Log.Debugf("StartMessageHandle :%s", msg.TaskId)
- return nil
- }
- func (t *TaskSchedule) StopMessageHandle(msg *rule.TaskLifecycleMessage) error {
- t.cron.Stop(msg.TaskId)
- server.Log.Debugf("StopMessageHandle :%s", msg.TaskId)
- return nil
- }
|