scheduler.go 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115
  1. package internal
  2. import (
  3. "context"
  4. "encoding/json"
  5. "github.com/gogf/gf/container/gmap"
  6. "github.com/gogf/gf/encoding/gjson"
  7. "github.com/gogf/gf/frame/g"
  8. "github.com/gogf/gf/v2/os/gcron"
  9. "sparrow/pkg/rule"
  10. "sparrow/pkg/server"
  11. )
  12. // TaskSchedule task schedule 任务调度
  13. type TaskSchedule struct {
  14. tasks *gmap.HashMap // 保存任务名称与任务实体的映射
  15. cron *gcron.Cron
  16. }
  17. func NewTaskSchedule() *TaskSchedule {
  18. return &TaskSchedule{
  19. tasks: gmap.NewHashMap(true),
  20. cron: gcron.New(),
  21. }
  22. }
  23. func (t *TaskSchedule) AddTask(msg []byte) error {
  24. var task rule.TimerTaskMessage
  25. err := json.Unmarshal([]byte(msg), &task)
  26. if err != nil {
  27. return err
  28. }
  29. // 如果已经存在相同任务Id
  30. if t.tasks.Contains(task.TaskId) {
  31. return nil
  32. }
  33. newJson := gjson.New(task.Actions)
  34. server.Log.Debugf("add task: taskId:%s,corn:%s,times:%d,actions:%s", task.TaskId, task.Cron, task.Times, newJson.MustToJsonString())
  35. // 创建任务
  36. entity, err := t.cron.AddTimes(context.Background(), task.Cron, task.Times, func(ctx context.Context) {
  37. if err = NewTaskExecutor(task.Actions).Do(); err != nil {
  38. server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
  39. }
  40. _ = t.executeNotice(task.TaskId)
  41. }, task.TaskId)
  42. if err != nil {
  43. return err
  44. }
  45. t.tasks.Set(task.TaskId, entity)
  46. server.Log.Debugf("add a new timer task :%s", task.TaskId)
  47. return nil
  48. }
  49. func (t *TaskSchedule) AddMessageHandle(msg *rule.TaskLifecycleMessage) error {
  50. return nil
  51. }
  52. func (t *TaskSchedule) RemoveMessageHandle(msg *rule.TaskLifecycleMessage) error {
  53. t.cron.Remove(msg.TaskId)
  54. _ = t.tasks.Remove(msg.TaskId)
  55. server.Log.Debugf("RemoveMessageHandle :%s", msg.TaskId)
  56. return nil
  57. }
  58. func (t *TaskSchedule) UpdateMessageHandle(msg *rule.TaskLifecycleMessage) error {
  59. t.cron.Remove(msg.TaskId)
  60. var task rule.TimerTaskMessage
  61. _ = json.Unmarshal([]byte(msg.Data), &task)
  62. entity, err := t.cron.Add(context.Background(), task.Cron, func(ctx context.Context) {
  63. if err := NewTaskExecutor(task.Actions).Do(); err != nil {
  64. server.Log.Errorf("do taskid :%s error:%s", task.TaskId, err.Error())
  65. }
  66. }, msg.TaskId)
  67. if err != nil {
  68. return err
  69. }
  70. t.tasks.Set(msg.TaskId, entity)
  71. server.Log.Debugf("UpdateMessageHandle :%s", msg.TaskId)
  72. return nil
  73. }
  74. func (t *TaskSchedule) SnapMessageHandle(msg *rule.TaskLifecycleMessage) error {
  75. t.cron.Stop(msg.TaskId)
  76. server.Log.Debugf("SnapMessageHandle :%s", msg.TaskId)
  77. return nil
  78. }
  79. func (t *TaskSchedule) StartMessageHandle(msg *rule.TaskLifecycleMessage) error {
  80. t.cron.Start(msg.TaskId)
  81. server.Log.Debugf("StartMessageHandle :%s", msg.TaskId)
  82. return nil
  83. }
  84. func (t *TaskSchedule) StopMessageHandle(msg *rule.TaskLifecycleMessage) error {
  85. t.cron.Stop(msg.TaskId)
  86. server.Log.Debugf("StopMessageHandle :%s", msg.TaskId)
  87. return nil
  88. }
  89. func (t *TaskSchedule) executeNotice(taskId string) error {
  90. client := g.Client()
  91. client.SetHeader("Content-NoticeType", "application/json")
  92. args := gjson.New("")
  93. _ = args.Set("condition_id", taskId)
  94. r, err := g.Client().Post(server.GetRPCHost(), "http://192.168.0.62:8199/web/v1/scenes/execute_notice", args)
  95. if err != nil {
  96. server.Log.Errorf("execute notice error:%s", err.Error())
  97. }
  98. defer r.Close()
  99. return nil
  100. }