task.go 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381
  1. package services
  2. import (
  3. "context"
  4. "eta/eta_task/services/data"
  5. "eta/eta_task/services/data/future_good"
  6. "eta/eta_task/services/data_stat"
  7. "eta/eta_task/utils"
  8. "fmt"
  9. "sync"
  10. "time"
  11. "github.com/beego/beego/v2/task"
  12. )
  13. func Task() {
  14. fmt.Println("task start")
  15. //如果是生产环境,才需要走这些任务
  16. if utils.RunMode == "release" {
  17. releaseTask()
  18. }
  19. // 定时发布智能研报
  20. publishSmartReport := task.NewTask("publishSmartReport", "0 */1 * * * *", PublishSmartReport)
  21. task.AddTask("定时发布智能研报", publishSmartReport)
  22. // 定时发布研报
  23. publishReport := task.NewTask("publishReport", "0 */1 * * * *", PublishReport)
  24. task.AddTask("定时发布研报", publishReport)
  25. // 定时汇总数据源终端指标更新情况
  26. setEdbSourceStatTask := task.NewTask("setEdbSourceStatTask", "0 20 19,23 * * *", data_stat.SetEdbSourceStatTask)
  27. task.AddTask("数据源统计表", setEdbSourceStatTask)
  28. // 定时监测AI任务调度情况
  29. if utils.BusinessCode == utils.BusinessCodeRelease || utils.BusinessCode == utils.BusinessCodeDebug {
  30. checkAiTask := task.NewTask("checkAiTask", "0 */5 * * * *", CheckAiTask)
  31. task.AddTask("定时定时监测AI任务调度情况", checkAiTask)
  32. }
  33. // 定时禁用钢联化工和wind指标的刷新状态
  34. disableEdbRefresh := task.NewTask("disableEdbRefresh", "0 0 10 * * *", DisableEdbRefresh)
  35. task.AddTask("disableEdbRefresh", disableEdbRefresh)
  36. // 根据配置对指标的刷新做巡检
  37. addEdbInspectionRecord := task.NewTask("addEdbInspectionRecord", "0 */30 * * * * ", AddEdbInspectionRecord)
  38. task.AddTask("addEdbInspectionRecord", addEdbInspectionRecord)
  39. XyTask()
  40. // 测试-刷新多空分析/相关性表格
  41. if utils.RunMode == "debug" {
  42. refreshTradeAnalysisTables := task.NewTask("refreshTradeAnalysisTables", "0 0 20 * * *", data.RefreshTradeAnalysisTables)
  43. task.AddTask("refreshTradeAnalysisTables", refreshTradeAnalysisTables)
  44. }
  45. // 测试-同步数据源ES
  46. if utils.RunMode == "debug" {
  47. syncDataSourceEs := task.NewTask("syncDataSourceEs", "0 30 4 * * *", data.SyncDataSourceEs)
  48. task.AddTask("syncDataSourceEs", syncDataSourceEs)
  49. }
  50. task.StartTask()
  51. fmt.Println("task end")
  52. }
  53. // 生产环境需要走的任务
  54. func releaseTask() {
  55. //同步指标
  56. if utils.BusinessCode != utils.BusinessCodeRelease {
  57. syncHzDataIndex := task.NewTask("syncHzDataIndex", "0 10,20,40,50 16,18 * * *", SyncHzDataIndex)
  58. task.AddTask("syncHzDataIndex", syncHzDataIndex)
  59. syncRankingFromDalian := task.NewTask("syncRankingFromDalian", "0 30,40,50 16,18 * * *", SyncRankingFromDalian)
  60. task.AddTask("syncRankingFromDalian", syncRankingFromDalian)
  61. }
  62. if utils.BusinessCode == utils.BusinessCodeRelease {
  63. // 定时刷新公众号文章
  64. refreshWechatPlatform := task.NewTask("refreshWechatPlatform", "0 0 14 * * *", RefreshWechatPlatform)
  65. task.AddTask("定时刷新公众号文章", refreshWechatPlatform)
  66. }
  67. // 定时统计交易所的持仓分析数据
  68. initPositionTask := task.NewTask("initPositionTask", "0 20,40 16-19 * * *", data.InitPositionTask)
  69. task.AddTask("initPositionTask", initPositionTask)
  70. //刷新指标数据
  71. refreshData := task.NewTask("refreshData", "0 30 0,19 * * *", RefreshData)
  72. task.AddTask("refreshData", refreshData)
  73. // 根据配置刷新指标数据
  74. configRefreshData := task.NewTask("syncBaseDataExt", "0 */30 * * * * ", ConfigRefreshData)
  75. task.AddTask("configRefreshData", configRefreshData)
  76. // 定时刷新计算指标-默认每天的7:05,8:05分刷新计算指标
  77. refreshCalculateEdbTaskTime := utils.RefreshCalculateEdbTaskTime
  78. if refreshCalculateEdbTaskTime == "" {
  79. refreshCalculateEdbTaskTime = "0 5 7,8 * * *"
  80. }
  81. refreshAllCalculateEdbData := task.NewTask("refreshAllCalculateEdbData", refreshCalculateEdbTaskTime, RefreshAllCalculateEdbData)
  82. task.AddTask("refreshAllCalculateEdbData", refreshAllCalculateEdbData)
  83. // 定时禁用钢联化工和wind指标的刷新状态
  84. disableEdbRefresh := task.NewTask("disableEdbRefresh", "0 0 10 * * *", DisableEdbRefresh)
  85. task.AddTask("disableEdbRefresh", disableEdbRefresh)
  86. //同步弘则数据库中来自,钢联,隆众,有色,人工等基础数据--每隔五分钟,同步一次最新数据
  87. syncBaseData := task.NewTask("syncBaseData", "0 */5 * * * * ", SyncBaseData)
  88. task.AddTask("syncBaseData", syncBaseData)
  89. syncBaseDataExt := task.NewTask("syncBaseDataExt", "0 */30 * * * * ", SyncBaseDataExt)
  90. task.AddTask("syncBaseDataExt", syncBaseDataExt)
  91. //初始化指标更新状态
  92. resetEdbInfoIsUpdate := task.NewTask("resetEdbInfoIsUpdate", "0 0 0 * * *", data.ResetEdbInfoIsUpdate)
  93. task.AddTask("resetEdbInfoIsUpdate", resetEdbInfoIsUpdate)
  94. // 刷新商品数据
  95. refreshFutureGoodData := task.NewTask("refreshFutureGoodData", "0 30 0,19 * * *", RefreshFutureGoodData)
  96. task.AddTask("refreshFutureGoodData", refreshFutureGoodData)
  97. //刷新交易所指标数据
  98. refreshTradeData := task.NewTask("refreshData", "0 1 4 * * *", RefreshTradeData)
  99. task.AddTask("refreshTradeData", refreshTradeData)
  100. //刷新欧洲天然气指标数据
  101. refreshEicData := task.NewTask("refreshData", "0 1 3,7 * * *", RefreshEicData)
  102. task.AddTask("refreshEicData", refreshEicData)
  103. //检测数据服务器
  104. checkDataServer := task.NewTask("checkDataServer", "0 */2 * * * * ", checkDataServer)
  105. task.AddTask("checkDataServer", checkDataServer)
  106. //删除日志 report_save_log,ppt_v2_save_log,保留一个月的
  107. deleteLog := task.NewTask("syncSubStatus", "0 0 2 2 * *", DeleteLog)
  108. task.AddTask("deleteLog", deleteLog)
  109. // 定时发布英文研报
  110. publishEnglishReport := task.NewTask("publishEnglishReport", "0 */1 * * * *", PublishEnglishReport)
  111. task.AddTask("定时发布英文研报", publishEnglishReport)
  112. // 每天清理两周前的报告保存日志
  113. clearReportSaveLog := task.NewTask("clearReportSaveLog", "0 15 23 * * *", ClearReportSaveLog)
  114. task.AddTask("定时清理报告保存日志", clearReportSaveLog)
  115. // 每天清理三个月前的用户操作日志
  116. clearAdminOperateLog := task.NewTask("clearAdminOperateLog", "0 20 23 * * *", ClearAdminOperateLog)
  117. task.AddTask("定时清理用户操作日志", clearAdminOperateLog)
  118. // 嘉悦物产
  119. if utils.BusinessCode == utils.BusinessCodeJiaYue {
  120. // 每10分钟定时同步增量指标
  121. syncJiaYueNewIndex := task.NewTask("syncJiaYueNewIndex", "0 */10 * * * *", data.SyncJiaYueNewIndex)
  122. task.AddTask("定时同步嘉悦物产增量指标", syncJiaYueNewIndex)
  123. // 每30分钟同步一次数据宝指标数据
  124. syncJiaYueDataBaby := task.NewTask("syncJiaYueDataBaby", "0 */30 * * * * ", data.RefreshJiaYueDataFromBridge)
  125. task.AddTask("syncJiaYueDataBaby", syncJiaYueDataBaby)
  126. }
  127. if utils.BusinessCode == utils.BusinessCodeZhongJi {
  128. // 每天同步一次指标列表
  129. syncZhongJiIndexList := task.NewTask("syncZhongJiIndexList", "0 0 17 * * *", data.SyncZhongJiIndexList)
  130. task.AddTask("定时同步中基宁波SMM指标列表", syncZhongJiIndexList)
  131. }
  132. // 中石油新加坡
  133. if utils.IsPCSG == "1" {
  134. refreshPCSGBloomberg := task.NewTask("refreshPCSGBloombergDaily", "0 */30 * * * *", data.RefreshPCSGBloomberg)
  135. task.AddTask("中石油新加坡-每日Bloomberg指标刷新", refreshPCSGBloomberg)
  136. }
  137. // 刷新同花顺高频
  138. refreshThsHfBase := task.NewTask("refreshThsHfBase", "0 0 0,6,9,12,15,18,21 * * *", data.RefreshBaseFromThsHfIndex)
  139. task.AddTask("refreshThsHfBase", refreshThsHfBase)
  140. // (基于交易所数据)多空分析/相关性表格刷新
  141. refreshTradeAnalysisTables := task.NewTask("refreshTradeAnalysisTables", "0 0 20 * * *", data.RefreshTradeAnalysisTables)
  142. task.AddTask("refreshTradeAnalysisTables", refreshTradeAnalysisTables)
  143. // 每日同步数据源ES(business_conf可开关)
  144. syncDataSourceEs := task.NewTask("syncDataSourceEs", "0 30 4 * * *", data.SyncDataSourceEs)
  145. task.AddTask("syncDataSourceEs", syncDataSourceEs)
  146. }
  147. func RefreshData(cont context.Context) (err error) {
  148. wg := sync.WaitGroup{}
  149. wg.Add(12)
  150. //hour := time.Now().Hour()
  151. //if hour != 0 {
  152. //}
  153. //彭博
  154. //go data.RefreshDataFromPb(&wg)
  155. //彭博财务
  156. //go data.RefreshDataFromPbFinance(&wg)
  157. //手工数据
  158. go data.RefreshDataFromManual(&wg)
  159. //隆众数据
  160. //go data.RefreshDataFromLz(&wg)
  161. //有色
  162. go data.RefreshDataFromYs(&wg)
  163. //钢联
  164. go data.RefreshDataFromGl(&wg)
  165. //路透
  166. go data.RefreshDataFromLt(&wg)
  167. //煤炭
  168. go data.RefreshDataFromCoal(&wg)
  169. //谷歌出行数据
  170. go data.RefreshDataFromGoogleTravel(&wg)
  171. //钢联化工
  172. go data.RefreshDataFromMysteelChemical(&wg)
  173. //eia steo报告指标
  174. go data.RefreshDataFromEiaSteo(&wg)
  175. //UN报告指标
  176. go data.RefreshDataFromComTrade(&wg)
  177. //卓创报告指标
  178. go data.RefreshDataFromSci(&wg)
  179. //国家统计局指标
  180. go data.RefreshDataFromNationalStatistics(&wg)
  181. //富宝指标刷新
  182. go data.RefreshDataFromFubao(&wg)
  183. // Bloomberg
  184. go func() {
  185. wg.Add(1)
  186. _ = data.RefreshDataFromBloomberg(&wg)
  187. }()
  188. // CCF化纤信息
  189. go func() {
  190. wg.Add(1)
  191. _ = data.RefreshDataFromCCF(&wg)
  192. }()
  193. // 持仓分析
  194. go func() {
  195. wg.Add(1)
  196. _ = data.RefreshDataFromTradeAnalysis(&wg)
  197. }()
  198. wg.Wait()
  199. ////计算指标
  200. data.RefreshDataFromCalculateAll()
  201. // 刷新所有的基础预测指标
  202. data.RefreshBasePredictDataAll()
  203. // 预测计算指标
  204. data.RefreshPredictDataFromCalculateAll()
  205. // 指标系列计算数据
  206. _ = data.RefreshFactorEdbCalculateData()
  207. // 指标系列图表计算数据
  208. _ = data.RefreshFactorEdbChartCalculateData()
  209. // 刷新商品利润曲线图表数据
  210. _ = data.RefreshFutureGoodProfitChart()
  211. // 刷新计算指标-依赖指标id大于当前计算指标id的计算指标
  212. data.RefreshDataFromCalculateAfter()
  213. time.Sleep(5 * time.Second)
  214. //data.RefreshNotice()
  215. fmt.Println("Refresh End")
  216. return
  217. }
  218. // 刷新所有计算指标数据
  219. func RefreshAllCalculateEdbData(cont context.Context) (err error) {
  220. ////计算指标
  221. err = data.RefreshDataFromCalculateAll()
  222. return
  223. }
  224. // SyncBaseData 刷新基础数据
  225. func SyncBaseData(cont context.Context) (err error) {
  226. now := time.Now()
  227. if now.Hour() == 0 || now.Hour() == 19 {
  228. return nil
  229. }
  230. //同步钢联基础数据
  231. if utils.BusinessCode == utils.BusinessCodeRelease {
  232. go data.SyncGlDataBase()
  233. }
  234. return
  235. }
  236. // SyncBaseDataExt 刷新基础数据
  237. func SyncBaseDataExt(cont context.Context) (err error) {
  238. now := time.Now()
  239. if now.Hour() == 0 || now.Hour() == 19 {
  240. return nil
  241. }
  242. //同步手工数据
  243. go data.SyncManualDataBase()
  244. //刷新图表中,指标的最新日期
  245. go data.SetChartEdbEndDate()
  246. return
  247. }
  248. // RefreshFutureGoodData 刷新商品数据
  249. func RefreshFutureGoodData(cont context.Context) (err error) {
  250. future_good.RefreshFutureGoodDataFromThs()
  251. fmt.Println("Refresh End")
  252. return
  253. }
  254. // RefreshTradeData 刷新交易所数据
  255. func RefreshTradeData(cont context.Context) (err error) {
  256. wg := sync.WaitGroup{}
  257. wg.Add(6)
  258. //郑商所
  259. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_ZZ)
  260. //上期所
  261. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_SH)
  262. //上期能源
  263. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_SHFE)
  264. //中金所
  265. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_CFFEX)
  266. //大商所
  267. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_DL)
  268. //广期所数据
  269. go data.RefreshBaseDataFromSource(&wg, utils.DATA_SOURCE_GFEX)
  270. wg.Wait()
  271. //计算指标
  272. data.RefreshDataFromCalculateAll()
  273. // 刷新所有的基础预测指标
  274. data.RefreshBasePredictDataAll()
  275. // 计算预测指标
  276. data.RefreshPredictDataFromCalculateAll()
  277. return
  278. }
  279. // RefreshEicData 刷新欧洲天然气数据
  280. func RefreshEicData(cont context.Context) (err error) {
  281. wg := sync.WaitGroup{}
  282. wg.Add(1)
  283. //欧洲天然气
  284. go data.RefreshDataFromEic(&wg)
  285. wg.Wait()
  286. ////计算指标
  287. //data.RefreshDataFromCalculateAll()
  288. //
  289. //// 刷新所有的基础预测指标
  290. //data.RefreshBasePredictDataAll()
  291. //
  292. //// 计算预测指标
  293. //data.RefreshPredictDataFromCalculateAll()
  294. return
  295. }
  296. // 检测数据服务
  297. func checkDataServer(cont context.Context) (err error) {
  298. //检测wind新服务器
  299. go data.CheckWindDataInterface(cont)
  300. //检测同花顺数据服务器
  301. //go data.CheckThsDataInterface(cont)
  302. //检测路透数据服务器
  303. go data.CheckLtDataInterface(cont)
  304. //检测彭博
  305. go data.CheckPbDataInterface(cont)
  306. return
  307. }
  308. func TaskInit() {
  309. fmt.Println("TaskInit start")
  310. //data.InitGuangzhouPositionTask()
  311. fmt.Println("TaskInit end")
  312. return
  313. }