You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

cloudbrain_statistic.go 7.3 kB

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. package repo
  2. import (
  3. "time"
  4. "code.gitea.io/gitea/models"
  5. "code.gitea.io/gitea/modules/context"
  6. "code.gitea.io/gitea/modules/log"
  7. "code.gitea.io/gitea/modules/timeutil"
  8. )
  9. func CloudbrainDurationStatistic() {
  10. log.Info("Generate Cloudbrain Duration statistic begin")
  11. // yesterday := time.Now().AddDate(0, 0, -1).Format("2006-01-02")
  12. // CloudbrainDurationStatisticHour(yesterday)
  13. log.Info("Generate Cloudbrain Duration statistic end")
  14. }
  15. func CloudbrainDurationStatisticHour(ctx *context.Context) {
  16. hourTime := time.Now().Hour()
  17. dateTime := time.Now().Format("2006-01-02 15:04:05")
  18. dayTime := time.Now().Format("2006-01-02")
  19. currentTime := time.Now()
  20. m, _ := time.ParseDuration("-1h")
  21. beginTime := currentTime.Add(m).Unix()
  22. endTime := currentTime.Unix()
  23. // fmt.Println(beginTime)
  24. ciTasks1, err := models.GetCloudbrainRunning()
  25. if err != nil {
  26. // ctx.ServerError("Get job failed:", err)
  27. log.Info("GetCloudbrainRunning err: %v", err)
  28. return
  29. }
  30. ciTasks2, err := models.GetCloudbrainCompleteByTime(beginTime, endTime)
  31. ciTasks := append(ciTasks1, ciTasks2...)
  32. log.Info("beginTime: %s", beginTime)
  33. log.Info("endTime: %s", endTime)
  34. if err != nil {
  35. // ctx.ServerError("Get job failed:", err)
  36. log.Info("GetCloudbrainCompleteByTime err: %v", err)
  37. return
  38. }
  39. models.LoadSpecs4CloudbrainInfo(ciTasks)
  40. log.Info("ciTasks here: %s", ciTasks)
  41. log.Info("count here: %s", len(ciTasks))
  42. cloudBrainCenterCodeAndCardTypeInfo := getcloudBrainCenterCodeAndCardTypeInfo(ciTasks, beginTime, endTime)
  43. for centerCode, CardTypeInfo := range cloudBrainCenterCodeAndCardTypeInfo {
  44. for cardType, cardDuration := range CardTypeInfo {
  45. cloudbrain, err := models.GetSpecByAiCenterCodeAndType(centerCode, cardType)
  46. if err != nil {
  47. log.Info("GetSpecByAiCenterCodeAndType err: %v", err)
  48. return
  49. }
  50. log.Info("cloudbrain: %s", cloudbrain)
  51. if cloudbrain != nil {
  52. totalUse := true
  53. totalCanUse := false
  54. if err := models.DeleteCloudbrainDurationStatisticHour(dayTime, hourTime, centerCode, cardType, totalUse, totalCanUse); err != nil {
  55. log.Error("DeleteCloudbrainDurationStatisticHour failed: %v", err.Error())
  56. return
  57. }
  58. cloudbrainDurationStat := models.CloudbrainDurationStatistic{
  59. DateTime: dateTime,
  60. DayTime: dayTime,
  61. HourTime: hourTime,
  62. Cluster: cloudbrain[0].Cluster,
  63. AiCenterName: cloudbrain[0].AiCenterName,
  64. AiCenterCode: centerCode,
  65. ComputeResource: cloudbrain[0].ComputeResource,
  66. AccCardType: cardType,
  67. CardsTotalDuration: cardDuration,
  68. CreatedTime: timeutil.TimeStampNow(),
  69. TotalUse: true,
  70. TotalCanUse: false,
  71. }
  72. if _, err = models.InsertCloudbrainDurationStatistic(&cloudbrainDurationStat); err != nil {
  73. log.Error("Insert cloudbrainDurationStat failed: %v", err.Error())
  74. }
  75. }
  76. }
  77. }
  78. resourceQueues, err := models.GetCanUseCardInfo()
  79. if err != nil {
  80. log.Info("GetCanUseCardInfo err: %v", err)
  81. return
  82. }
  83. log.Info("resourceQueues here: %s", resourceQueues)
  84. for _, resourceQueue := range resourceQueues {
  85. totalUse := false
  86. totalCanUse := true
  87. if err := models.DeleteCloudbrainDurationStatisticHour(dayTime, hourTime, resourceQueue.AiCenterCode, resourceQueue.AccCardType, totalUse, totalCanUse); err != nil {
  88. log.Error("DeleteCloudbrainDurationStatisticHour failed: %v", err.Error())
  89. return
  90. }
  91. cardsTotalDuration := resourceQueue.CardsTotalNum * 1 * 60 * 60
  92. cloudbrainDurationStat := models.CloudbrainDurationStatistic{
  93. DateTime: dateTime,
  94. DayTime: dayTime,
  95. HourTime: hourTime,
  96. Cluster: resourceQueue.Cluster,
  97. AiCenterName: resourceQueue.AiCenterName,
  98. AiCenterCode: resourceQueue.AiCenterCode,
  99. ComputeResource: resourceQueue.ComputeResource,
  100. AccCardType: resourceQueue.AccCardType,
  101. CardsTotalDuration: cardsTotalDuration,
  102. CardsTotalNum: resourceQueue.CardsTotalNum,
  103. CreatedTime: timeutil.TimeStampNow(),
  104. TotalUse: false,
  105. TotalCanUse: true,
  106. }
  107. if _, err = models.InsertCloudbrainDurationStatistic(&cloudbrainDurationStat); err != nil {
  108. log.Error("Insert cloudbrainDurationStat failed: %v", err.Error())
  109. }
  110. }
  111. log.Info("finish summary cloudbrainDurationStat")
  112. }
  113. func getcloudBrainCenterCodeAndCardTypeInfo(ciTasks []*models.CloudbrainInfo, beginTime int64, endTime int64) map[string]map[string]int {
  114. var WorkServerNumber int
  115. var AccCardsNum int
  116. // cloudBrainCardRes := make(map[string]int)
  117. cloudBrainAiCenterCodeList := make(map[string]string)
  118. cloudBrainCardTypeList := make(map[string]string)
  119. cloudBrainCenterCodeAndCardType := make(map[string]map[string]int)
  120. for _, cloudbrain := range ciTasks {
  121. if _, ok := cloudBrainAiCenterCodeList[cloudbrain.Cloudbrain.Spec.AiCenterCode]; !ok {
  122. cloudBrainAiCenterCodeList[cloudbrain.Cloudbrain.Spec.AiCenterCode] = cloudbrain.Cloudbrain.Spec.AiCenterCode
  123. }
  124. if cloudbrain.Cloudbrain.StartTime == 0 {
  125. cloudbrain.Cloudbrain.StartTime = cloudbrain.Cloudbrain.CreatedUnix
  126. }
  127. if cloudbrain.Cloudbrain.EndTime == 0 {
  128. cloudbrain.Cloudbrain.EndTime = cloudbrain.Cloudbrain.UpdatedUnix
  129. }
  130. if cloudbrain.Cloudbrain.WorkServerNumber >= 1 {
  131. WorkServerNumber = cloudbrain.Cloudbrain.WorkServerNumber
  132. } else {
  133. WorkServerNumber = 1
  134. }
  135. if cloudbrain.Cloudbrain.Spec == nil {
  136. AccCardsNum = 1
  137. } else {
  138. AccCardsNum = cloudbrain.Cloudbrain.Spec.AccCardsNum
  139. }
  140. for k, _ := range cloudBrainAiCenterCodeList {
  141. if cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]] == nil {
  142. cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]] = make(map[string]int)
  143. }
  144. if cloudbrain.Cloudbrain.Spec.AiCenterCode == cloudBrainAiCenterCodeList[k] {
  145. if _, ok := cloudBrainCardTypeList[cloudbrain.Cloudbrain.Spec.AccCardType]; !ok {
  146. cloudBrainCardTypeList[cloudbrain.Cloudbrain.Spec.AccCardType] = cloudbrain.Cloudbrain.Spec.AccCardType
  147. }
  148. for i, _ := range cloudBrainCardTypeList {
  149. if cloudbrain.Cloudbrain.Spec.AccCardType == cloudBrainCardTypeList[i] {
  150. if cloudbrain.Cloudbrain.Status == string(models.ModelArtsRunning) {
  151. if int64(cloudbrain.Cloudbrain.StartTime) < beginTime {
  152. cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]][cloudBrainCardTypeList[i]] += AccCardsNum * WorkServerNumber * (int(endTime) - int(beginTime))
  153. } else {
  154. cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]][cloudBrainCardTypeList[i]] += AccCardsNum * WorkServerNumber * (int(endTime) - int(cloudbrain.Cloudbrain.StartTime))
  155. }
  156. } else {
  157. if int64(cloudbrain.Cloudbrain.StartTime) < beginTime && int64(cloudbrain.Cloudbrain.EndTime) < endTime {
  158. cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]][cloudBrainCardTypeList[i]] += AccCardsNum * WorkServerNumber * (int(cloudbrain.Cloudbrain.EndTime) - int(beginTime))
  159. } else {
  160. cloudBrainCenterCodeAndCardType[cloudBrainAiCenterCodeList[k]][cloudBrainCardTypeList[i]] += AccCardsNum * WorkServerNumber * (int(cloudbrain.Cloudbrain.EndTime) - int(cloudbrain.Cloudbrain.StartTime))
  161. }
  162. }
  163. }
  164. }
  165. }
  166. }
  167. }
  168. return cloudBrainCenterCodeAndCardType
  169. }