task.go 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. package init_serve
  2. import (
  3. "eta/mysteel_watch/services"
  4. "eta/mysteel_watch/utils"
  5. "eta/mysteel_watch/watch"
  6. "github.com/robfig/cron/v3"
  7. "time"
  8. "eta/mysteel_watch/global"
  9. "eta/mysteel_watch/services/alarm_msg"
  10. )
  11. func InitTask() {
  12. c := cron.New(cron.WithSeconds())
  13. //每1分钟检测一次,指标生成
  14. _, err := c.AddFunc("0 */5 * * * *", CheckIndexCreateMerge)
  15. if err != nil {
  16. global.LOG.Info("DownloadCvTask err" + err.Error())
  17. }
  18. //每天17点刷新指标
  19. _, err = c.AddFunc("0 0 17 * * *", services.MergeV2)
  20. if err != nil {
  21. global.LOG.Info("DownloadCvTask err" + err.Error())
  22. }
  23. //每2分钟检测一次指标文件是否更新
  24. _, err = c.AddFunc("0 */2 * * * *", watch.ReadWatchIndexFile)
  25. _, err = c.AddFunc("0 0 17 1 * *", services.MergeMonthSeasonYearV2)
  26. if err != nil {
  27. global.LOG.Info("DownloadCvTask err" + err.Error())
  28. }
  29. // 服务检测
  30. _, err = c.AddFunc("0 */1 * * * *", services.ServerCheck)
  31. if err != nil {
  32. global.LOG.Info("ServerCheck err" + err.Error())
  33. }
  34. // 指标更新检测
  35. if global.CONFIG.Serve.IsCheckIndexUpdate {
  36. services.IndexUpdateCheck()
  37. _, err = c.AddFunc("0 30 17 * * *", services.IndexUpdateCheck)
  38. if err != nil {
  39. global.LOG.Info("IndexUpdateCheck err" + err.Error())
  40. }
  41. }
  42. c.Start()
  43. }
  44. // CheckIndexCreate 检测指标数据是否生成
  45. func CheckIndexCreate() {
  46. var err error
  47. defer func() {
  48. if err != nil && err.Error() != "record not found" {
  49. global.LOG.Info(utils.APPNAME + " 定时任务 出错" + time.Now().Format("2006-01-02 15:04:05") + ";Err:" + err.Error())
  50. go alarm_msg.SendAlarmMsg(utils.APPNAME+" 定时任务 出错"+time.Now().Format("2006-01-02 15:04:05")+";Err:"+err.Error(), 3)
  51. }
  52. }()
  53. err = services.IndexCreateCheck()
  54. }
  55. // CheckIndexCreate 检测指标数据是否生成
  56. func CheckIndexCreateMerge() {
  57. var err error
  58. defer func() {
  59. if err != nil && err.Error() != "record not found" {
  60. global.LOG.Info(utils.APPNAME + " 定时任务 出错" + time.Now().Format("2006-01-02 15:04:05") + ";Err:" + err.Error())
  61. //go alarm_msg.SendAlarmMsg(utils.APPNAME+" 定时任务 出错"+time.Now().Format("2006-01-02 15:04:05")+";Err:"+err.Error(), 3)
  62. }
  63. }()
  64. err = services.IndexCreateCheckMerge()
  65. }