task.go 2.3 KB

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