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