main.go 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. package main
  2. import (
  3. _ "eta/eta_mini_ht_api/common/component"
  4. "eta/eta_mini_ht_api/common/component/config"
  5. logger "eta/eta_mini_ht_api/common/component/log"
  6. "eta/eta_mini_ht_api/common/contants"
  7. "eta/eta_mini_ht_api/common/exception"
  8. "eta/eta_mini_ht_api/domian/report"
  9. "eta/eta_mini_ht_api/models/eta"
  10. "eta/eta_mini_ht_api/models/ht"
  11. _ "eta/eta_mini_ht_api/routers"
  12. _ "eta/eta_mini_ht_api/task"
  13. "github.com/beego/beego/v2/server/web"
  14. "log"
  15. "sync"
  16. "time"
  17. )
  18. func main() {
  19. if web.BConfig.RunMode == "dev" {
  20. web.BConfig.WebConfig.DirectoryIndex = true
  21. web.BConfig.WebConfig.StaticDir["/swagger"] = "swagger"
  22. }
  23. sysConfig := config.GetConfig(contants.HT).(*config.HTBizConfig)
  24. configPath := sysConfig.ConfigPath()
  25. if configPath != "" {
  26. logger.Info("加载配置文件:%v", configPath)
  27. err := web.LoadAppConfig("ini", configPath)
  28. if err != nil {
  29. log.Fatalf("web.LoadAppConfig Err:%v", err)
  30. }
  31. }
  32. //web.ErrorHandler("*", exception.ControllerAdvice())
  33. web.BConfig.RecoverFunc = exception.PanicAdvice
  34. go func() {
  35. //内存数据预热预加载
  36. logger.Info("开始预加载数据")
  37. //初始化研报库
  38. initReport()
  39. }()
  40. logger.Info("初始化成功")
  41. web.Run()
  42. }
  43. func initReport() {
  44. var wg sync.WaitGroup
  45. wg.Add(2)
  46. logger.Info("开始初始化研报库")
  47. go func() {
  48. defer wg.Done()
  49. for {
  50. id, err := report.GetETALatestReportId()
  51. var etaReportList []eta.ETAReport
  52. etaReportList, err = eta.GetETAReports(id)
  53. if err != nil {
  54. logger.Error("获取ETA研报列表失败:%v", err)
  55. }
  56. if len(etaReportList) > 0 {
  57. err = report.InitETAReportList(etaReportList)
  58. if err != nil {
  59. logger.Error("同步ETA研报列表失败:%v", err)
  60. }
  61. } else {
  62. logger.Info(contants.TaskFormat, "同步ETA研报库结束")
  63. break
  64. }
  65. }
  66. }()
  67. go func() {
  68. defer wg.Done()
  69. for {
  70. id, err := report.GetHTLatestReportId()
  71. var htReportList []ht.HTReport
  72. htReportList, err = ht.GetHTReports(id)
  73. if err != nil {
  74. logger.Error("获取ETA研报列表失败:%v", err)
  75. }
  76. if len(htReportList) > 0 {
  77. for i := 0; i < len(htReportList); i++ {
  78. timestamp := int64(htReportList[i].PublishTime)
  79. t := time.UnixMilli(timestamp)
  80. htReportList[i].PublishedTime = t.Format(time.DateTime)
  81. plateId := htReportList[i].PlateId
  82. plate, err := ht.GetPermissionNameById(plateId)
  83. if err != nil || plate.ParentId == 0 {
  84. htReportList[i].PermissionName = htReportList[i].PlateName
  85. } else {
  86. PermissionName, err := getPermissionNameById(plate.ParentId)
  87. if err != nil {
  88. logger.Error("获取ETA研报列表失败:%v", err)
  89. htReportList[i].PermissionName = ""
  90. } else {
  91. htReportList[i].PermissionName = PermissionName
  92. }
  93. }
  94. }
  95. var stop bool
  96. stop, err = report.InitHTReportList(htReportList)
  97. if err != nil {
  98. logger.Error("同步ETA研报列表失败:%v", err)
  99. break
  100. }
  101. if stop {
  102. logger.Info(contants.TaskFormat, "同步HT研报库结束")
  103. break
  104. }
  105. } else {
  106. logger.Info(contants.TaskFormat, "同步HT研报库结束")
  107. break
  108. }
  109. }
  110. }()
  111. wg.Wait()
  112. logger.Info("初始化研报库完成")
  113. }
  114. func getPermissionNameById(id int) (name string, err error) {
  115. plate, err := ht.GetPermissionNameById(id)
  116. if err != nil {
  117. return
  118. }
  119. if plate.ParentId != 0 {
  120. return getPermissionNameById(plate.ParentId)
  121. } else {
  122. return plate.PlateName, nil
  123. }
  124. }