task.go 3.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110
  1. package init_serve
  2. import (
  3. "fmt"
  4. "github.com/robfig/cron/v3"
  5. "hongze/mysteel_watch/services"
  6. "hongze/mysteel_watch/utils"
  7. "hongze/mysteel_watch/watch"
  8. "time"
  9. "hongze/mysteel_watch/global"
  10. "hongze/mysteel_watch/services/alarm_msg"
  11. )
  12. func InitTask() {
  13. c := cron.New(cron.WithSeconds())
  14. //每1分钟检测一次,指标生成
  15. _, err := c.AddFunc("0 */1 * * * *", CheckIndexCreate)
  16. if err != nil {
  17. global.LOG.Info("DownloadCvTask err" + err.Error())
  18. }
  19. //每30分钟检测一次,周度指标刷新
  20. //_, err = c.AddFunc("0 */30 * * * *", services.IndexRefreshWeek)
  21. //_, err = c.AddFunc("0 */5 * * * *", services.IndexRefreshWeek)
  22. //if err != nil {
  23. // global.LOG.Info("DownloadCvTask err" + err.Error())
  24. // panic("DownloadCvTask err" + err.Error())
  25. //}
  26. _, err = c.AddFunc("0 0 7,17 * * *", services.MergeV2)
  27. if err != nil {
  28. global.LOG.Info("DownloadCvTask err" + err.Error())
  29. }
  30. _, err = c.AddFunc("0 0 17 1 * *", services.MergeMonthSeasonYearV2)
  31. if err != nil {
  32. global.LOG.Info("DownloadCvTask err" + err.Error())
  33. }
  34. ////单独刷新甲醇指标
  35. //_, err = c.AddFunc("0 00 18 * * *", services.IndexRefreshMethanol)
  36. ////_, err = c.AddFunc("0 */12 * * * *", services.IndexRefreshMethanol)
  37. //if err != nil {
  38. // global.LOG.Info("DownloadCvTask err" + err.Error())
  39. //}
  40. //// 合并指标
  41. //_, err = c.AddFunc("0 */10 * * * *", services.Merge)
  42. ////_, err = c.AddFunc("0 */2 * * * *", services.Merge)
  43. //if err != nil {
  44. // global.LOG.Info("DownloadCvTask err" + err.Error())
  45. //}
  46. ////检测需要及时刷新的指标
  47. ////_, err = c.AddFunc("0 30 17 * * *", services.IndexRefreshTimely)
  48. //_, err = c.AddFunc("0 */5 * * * *", services.IndexRefreshTimely)
  49. //if err != nil {
  50. // global.LOG.Info("DownloadCvTask err" + err.Error())
  51. //}
  52. //其他指标刷新
  53. //_, err = c.AddFunc("0 30 12 * * *", services.IndexRefreshAll)
  54. //_, err = c.AddFunc("0 48 17 * * *", services.IndexRefreshAll)
  55. //if err != nil {
  56. // global.LOG.Info("DownloadCvTask err" + err.Error())
  57. // panic("DownloadCvTask err" + err.Error())
  58. //}
  59. // 服务检测
  60. _, err = c.AddFunc("0 */1 * * * *", services.ServerCheck)
  61. if err != nil {
  62. global.LOG.Info("ServerCheck err" + err.Error())
  63. }
  64. c.Start()
  65. ////go watch.ListenFolderNew()
  66. go watch.ListenFolderNew()
  67. go watch.ListenFolderNewMerge()
  68. //redis 队列刷新指标
  69. go services.AutoRefresh()
  70. //CheckIndexCreate()
  71. fmt.Println("start services.Merge")
  72. //services.Merge()
  73. //yearFile="year.xlsx"
  74. //filePath := global.CONFIG.Serve.IndexMergeSaveDir + "season.xlsx"
  75. //services.DataAnalysis(filePath)
  76. //services.Merge()
  77. fmt.Println("end services.Merge")
  78. }
  79. // 检测指标数据是否生成
  80. func CheckIndexCreate() {
  81. var err error
  82. defer func() {
  83. if err != nil && err.Error() != "record not found" {
  84. global.LOG.Info(utils.APPNAME + " 定时任务 出错" + time.Now().Format("2006-01-02 15:04:05") + ";Err:" + err.Error())
  85. go alarm_msg.SendAlarmMsg(utils.APPNAME+" 定时任务 出错"+time.Now().Format("2006-01-02 15:04:05")+";Err:"+err.Error(), 3)
  86. }
  87. }()
  88. err = services.IndexCreateCheck()
  89. }