scheduler.go 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. package internal
  2. import (
  3. "context"
  4. "encoding/json"
  5. "github.com/gogf/gf/container/gmap"
  6. "github.com/gogf/gf/v2/os/gcron"
  7. "sparrow/pkg/rule"
  8. "sparrow/pkg/server"
  9. )
  10. // TaskSchedule task schedule 任务调度
  11. type TaskSchedule struct {
  12. tasks *gmap.HashMap // 保存任务名称与任务实体的映射
  13. }
  14. func NewTaskSchedule() *TaskSchedule {
  15. return &TaskSchedule{
  16. tasks: gmap.NewHashMap(true),
  17. }
  18. }
  19. func (t *TaskSchedule) AddTask(msg []byte) error {
  20. var task rule.TimerTaskMessage
  21. err := json.Unmarshal([]byte(msg), &task)
  22. if err != nil {
  23. return err
  24. }
  25. // 如果已经存在相同任务Id
  26. if t.tasks.Contains(task.TaskId) {
  27. return nil
  28. }
  29. // 创建任务
  30. entity, err := gcron.Add(context.Background(), task.Cron, func(ctx context.Context) {
  31. if err = NewTaskExecutor(task.Actions).Do(); err != nil {
  32. server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
  33. }
  34. }, task.TaskId)
  35. if err != nil {
  36. return err
  37. }
  38. t.tasks.Set(task.TaskId, entity)
  39. server.Log.Debugf("add a new timer task :%s", task.TaskId)
  40. return nil
  41. }
  42. func (t *TaskSchedule) AddMessageHandle(msg *rule.TaskLifecycleMessage) error {
  43. return nil
  44. }
  45. func (t *TaskSchedule) RemoveMessageHandle(msg *rule.TaskLifecycleMessage) error {
  46. gcron.Remove(msg.TaskId)
  47. _ = t.tasks.Remove(msg.TaskId)
  48. server.Log.Debugf("RemoveMessageHandle :%s", msg.TaskId)
  49. return nil
  50. }
  51. func (t *TaskSchedule) UpdateMessageHandle(msg *rule.TaskLifecycleMessage) error {
  52. gcron.Remove(msg.TaskId)
  53. var task rule.TimerTaskMessage
  54. _ = json.Unmarshal([]byte(msg.Data), &task)
  55. entity, err := gcron.Add(context.Background(), task.Cron, func(ctx context.Context) {
  56. if err := NewTaskExecutor(task.Actions).Do(); err != nil {
  57. server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
  58. }
  59. }, task.TaskId)
  60. if err != nil {
  61. return err
  62. }
  63. t.tasks.Set(task.TaskId, entity)
  64. server.Log.Debugf("UpdateMessageHandle :%s", task.TaskId)
  65. return nil
  66. }
  67. func (t *TaskSchedule) SnapMessageHandle(msg *rule.TaskLifecycleMessage) error {
  68. gcron.Stop(msg.TaskId)
  69. server.Log.Debugf("SnapMessageHandle :%s", msg.TaskId)
  70. return nil
  71. }
  72. func (t *TaskSchedule) StartMessageHandle(msg *rule.TaskLifecycleMessage) error {
  73. gcron.Start(msg.TaskId)
  74. server.Log.Debugf("StartMessageHandle :%s", msg.TaskId)
  75. return nil
  76. }
  77. func (t *TaskSchedule) StopMessageHandle(msg *rule.TaskLifecycleMessage) error {
  78. gcron.Stop(msg.TaskId)
  79. server.Log.Debugf("StopMessageHandle :%s", msg.TaskId)
  80. return nil
  81. }