datastat.go 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. package main
  2. import (
  3. "runtime/debug"
  4. "time"
  5. "github.com/sirupsen/logrus"
  6. "lc/common/models"
  7. "lc/common/util"
  8. )
  9. var (
  10. StatYestodayStartMinute = 30
  11. StatCurrentdayStartMinute = 10
  12. )
  13. // CalcLightingRate 临时使用
  14. func CalcLightingRate( /*t*/ time.Time) {
  15. t, err1 := util.MlParseTime("2020-08-04 00:00:00")
  16. if err1 == nil {
  17. for !t.After(util.MlNow()) {
  18. models.CalcLightingRate(t)
  19. t = t.AddDate(0, 0, 1)
  20. }
  21. }
  22. }
  23. func GetNext15minite(t time.Time) time.Time {
  24. t = t.Add(-time.Duration(t.Second()) * time.Second) //去掉秒钟部分
  25. t = t.Add(-time.Duration(t.Nanosecond()) * time.Nanosecond) //去掉秒钟部分
  26. if t.Minute()%15 == 0 {
  27. return t
  28. }
  29. m := t.Minute()
  30. next := 0
  31. t = t.Add(-time.Duration(t.Minute()) * time.Minute) //去掉分钟部分
  32. if m > 0 && m < 15 {
  33. next = 15
  34. } else if m > 15 && m < 30 {
  35. next = 30
  36. } else if m > 30 && m < 45 {
  37. next = 45
  38. } else if m > 45 && m < 60 {
  39. next = 60
  40. }
  41. t = t.Add(time.Duration(next) * time.Minute)
  42. return t
  43. }
  44. func StatData(args ...interface{}) interface{} {
  45. defer func() {
  46. if err := recover(); err != nil {
  47. logrus.Error("StatData发生异常:", err)
  48. logrus.Error("StatData发生异常,堆栈:", string(debug.Stack()))
  49. gopool.Add(StatData, 1)
  50. }
  51. }()
  52. LastHour := util.BeginningOfHour().Add(1 * time.Hour)
  53. LastDay := util.BeginningOfDay()
  54. NextCalcMinuteRate := GetNext15minite(util.MlNow())
  55. //小于0点半启动,则还需要统计昨日的
  56. if time.Now().Minute() < StatYestodayStartMinute && time.Now().Hour() == 0 {
  57. LastDay = LastDay.Add(-24 * time.Hour)
  58. }
  59. //小于整点过10分启动,则需要统计当日的
  60. if time.Now().Minute() < StatCurrentdayStartMinute {
  61. LastHour = LastHour.Add(-1 * time.Hour)
  62. }
  63. for {
  64. //每天0点半执行昨日统计
  65. if util.BeginningOfDay().After(LastDay) && time.Now().Minute() > StatYestodayStartMinute {
  66. if err := models.StatDay(LastDay); err != nil {
  67. logrus.Errorf("统计日[%s]数据错误:%s", LastDay.Format("2006-01-02 15:04:05"), err.Error())
  68. }
  69. //统计昨日能耗
  70. if err := models.StatDayEnergy(util.MlNow(), 1); err != nil {
  71. logrus.Errorf("统计日能耗[%s]数据错误:%s", LastDay.Format("2006-01-02 15:04:05"), err.Error())
  72. }
  73. //统计当月能耗
  74. if err := models.StatMonthEnergy(util.MlNow(), 0); err != nil {
  75. logrus.Errorf("统计日能耗[%s]数据错误:%s", LastDay.Format("2006-01-02 15:04:05"), err.Error())
  76. }
  77. //月初第一天,还需要计算上月的统计
  78. if util.MlNow().Day() == 1 {
  79. if err := models.StatMonthEnergy(util.MlNow(), 1); err != nil {
  80. logrus.Errorf("统计月能耗[%s]数据错误:%s", LastDay.Format("2006-01-02 15:04:05"), err.Error())
  81. }
  82. }
  83. LastDay = util.BeginningOfDay()
  84. }
  85. //每日7点后整点过10分执行当日统计
  86. if time.Now().After(LastHour) && time.Now().Minute() >= StatCurrentdayStartMinute && time.Now().Hour() >= 6 {
  87. if err := models.StatDay(util.BeginningOfDay()); err != nil {
  88. logrus.Errorf("统计日[%s]数据错误:%s", LastHour.Format("2006-01-02 15:04:05"), err.Error())
  89. }
  90. //统计当日能耗
  91. if err := models.StatDayEnergy(util.MlNow(), 0); err != nil {
  92. logrus.Errorf("统计日能耗[%s]数据错误:%s", LastDay.Format("2006-01-02 15:04:05"), err.Error())
  93. }
  94. //每日8点统计昨日亮灯时长
  95. if time.Now().Hour() == 8 {
  96. tt := util.New(LastHour).BeginningOfDay().Add(-24 * time.Hour)
  97. err := models.CalcLightingRate(tt)
  98. if err != nil {
  99. return nil
  100. }
  101. }
  102. LastHour = LastHour.Add(1 * time.Hour)
  103. }
  104. //每15分钟统计一次小时亮灯率
  105. if util.MlNow().After(NextCalcMinuteRate) {
  106. err := models.CalcLightingMiniteRate(NextCalcMinuteRate)
  107. if err != nil {
  108. return nil
  109. }
  110. NextCalcMinuteRate = NextCalcMinuteRate.Add(time.Duration(15) * time.Minute)
  111. }
  112. time.Sleep(5 * time.Second)
  113. }
  114. return 0
  115. }