task.go 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  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. //每5分钟检测一次,指标生成
  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. //if err != nil {
  22. // global.LOG.Info("DownloadCvTask err" + err.Error())
  23. // panic("DownloadCvTask err" + err.Error())
  24. //}
  25. _, err = c.AddFunc("0 00 17 * * *", services.IndexRefreshAll)
  26. if err != nil {
  27. global.LOG.Info("DownloadCvTask err" + err.Error())
  28. }
  29. //单独刷新甲醇指标
  30. _, err = c.AddFunc("0 00 18 * * *", services.IndexRefreshMethanol)
  31. if err != nil {
  32. global.LOG.Info("DownloadCvTask err" + err.Error())
  33. }
  34. _, err = c.AddFunc("0 */10 * * * *", services.Merge)
  35. if err != nil {
  36. global.LOG.Info("DownloadCvTask err" + err.Error())
  37. }
  38. //检测需要及时刷新的指标
  39. _, err = c.AddFunc("0 30 17 * * *", services.IndexRefreshTimely)
  40. if err != nil {
  41. global.LOG.Info("DownloadCvTask err" + err.Error())
  42. }
  43. //
  44. ////其他指标刷新
  45. //_, err = c.AddFunc("0 30 12 * * *", services.IndexRefreshAll)
  46. //if err != nil {
  47. // global.LOG.Info("DownloadCvTask err" + err.Error())
  48. // panic("DownloadCvTask err" + err.Error())
  49. //}
  50. c.Start()
  51. //go watch.ListenFolderNew()
  52. go watch.ListenFolderNew()
  53. go watch.ListenFolderNewMerge()
  54. //redis 队列刷新指标
  55. go services.AutoRefresh()
  56. //CheckIndexCreate()
  57. fmt.Println("start services.Merge")
  58. //services.Merge()
  59. //yearFile="year.xlsx"
  60. //filePath := utils.IndexMsergeSaveDir + "season.xlsx"
  61. //services.DataAnalysis(filePath)
  62. //services.Merge()
  63. fmt.Println("end services.Merge")
  64. }
  65. //检测指标数据是否生成
  66. func CheckIndexCreate() {
  67. var err error
  68. defer func() {
  69. if err != nil && err.Error() != "record not found" {
  70. global.LOG.Info(utils.APPNAME + " 定时任务 出错" + time.Now().Format("2006-01-02 15:04:05") + ";Err:" + err.Error())
  71. go alarm_msg.SendAlarmMsg(utils.APPNAME+" 定时任务 出错"+time.Now().Format("2006-01-02 15:04:05")+";Err:"+err.Error(), 3)
  72. }
  73. }()
  74. err = services.IndexCreateCheck()
  75. }