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_dashboard.go 57 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
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
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
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
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
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
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
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
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
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
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
12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529
  1. package repo
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "strings"
  7. "time"
  8. "code.gitea.io/gitea/models"
  9. "code.gitea.io/gitea/modules/context"
  10. "code.gitea.io/gitea/modules/log"
  11. "code.gitea.io/gitea/routers/repo"
  12. "github.com/360EntSecGroup-Skylar/excelize/v2"
  13. )
  14. type DateCloudbrainNum struct {
  15. Date string `json:"date"`
  16. CloudOneJobTypeRes map[string]int `json:"cloudOneJobTypeRes"`
  17. CloudTwoJobTypeRes map[string]int `json:"cloudTwoJobTypeRes"`
  18. IntelligentNetJobTypeRes map[string]int `json:"intelligentNetJobTypeRes"`
  19. CDCenterJobTypeRes map[string]int `json:"cDCenterJobTypeRes"`
  20. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  21. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  22. }
  23. type DateCloudbrainInfo struct {
  24. Date string `json:"date"`
  25. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  26. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  27. }
  28. type CloudbrainsStatusAnalysis struct {
  29. JobWaitingCount int64 `json:"jobWaitingCount"`
  30. JobRunningCount int64 `json:"jobRunningCount"`
  31. JobStoppedCount int64 `json:"jobStoppedCount"`
  32. JobCompletedCount int64 `json:"jobCompletedCount"`
  33. JobFailedCount int64 `json:"jobFailedCount"`
  34. JobKilledCount int64 `json:"jobKilledCount"`
  35. JobInitCount int64 `json:"jobInitCount"`
  36. }
  37. func GetAllCloudbrainsOverview(ctx *context.Context) {
  38. recordCloudbrain, err := models.GetRecordBeginTime()
  39. if err != nil {
  40. log.Error("Can not get recordCloudbrain", err)
  41. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  42. return
  43. }
  44. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  45. now := time.Now()
  46. beginTime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  47. endTime := now
  48. todayCreatorCount, err := models.GetTodayCreatorCount(beginTime, endTime)
  49. if err != nil {
  50. log.Error("Can not query todayCreatorCount.", err)
  51. return
  52. }
  53. cloudbrainTypeCount, err := models.GetCloudbrainTypeCount()
  54. log.Info("cloudbrainTypeCount:", cloudbrainTypeCount)
  55. if err != nil {
  56. log.Error("Can not query cloudbrainTypeCount.", err)
  57. return
  58. }
  59. cloudbrainTpyeDurationSum, err := models.GetCloudbrainTpyeDurationSum()
  60. log.Info("cloudbrainTpyeDurationSum:", cloudbrainTpyeDurationSum)
  61. if err != nil {
  62. log.Error("Can not query cloudbrainTpyeDurationSum.", err)
  63. return
  64. }
  65. todayCloudbrainCount, err := models.GetTodayCloudbrainCount(beginTime, endTime)
  66. log.Info("todayCloudbrainCount:", todayCloudbrainCount)
  67. if err != nil {
  68. log.Error("Can not query todayCloudbrainCount.", err)
  69. return
  70. }
  71. todayRunningCount, err := models.GetTodayRunningCount(beginTime, endTime)
  72. log.Info("todayRunningCount:", todayRunningCount)
  73. if err != nil {
  74. log.Error("Can not query todayRunningCount.", err)
  75. return
  76. }
  77. todayWaitingCount, err := models.GetTodayWaitingCount(beginTime, endTime)
  78. log.Info("todayWaittingCount:", todayWaitingCount)
  79. if err != nil {
  80. log.Error("Can not query todayWaitingCount.", err)
  81. return
  82. }
  83. todayCompletedCount := todayCloudbrainCount - todayRunningCount - todayWaitingCount
  84. log.Info("todayCompletedCount:", todayCompletedCount)
  85. creatorCount, err := models.GetCreatorCount()
  86. if err != nil {
  87. log.Error("Can not query creatorCount.", err)
  88. return
  89. }
  90. // todayStatusResult := make(map[string]int)
  91. // cloudBrainNum := make(map[int]int)
  92. // cloudBrainOneDuration := int64(0)
  93. // cloudBrainTwoDuration := int64(0)
  94. // intelligentNetDuration := int64(0)
  95. // todayNewJobCount := 0
  96. // if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  97. // todayNewJobCount += 1
  98. // if _, ok := todayStatusResult[cloudbrain.Status]; !ok {
  99. // todayStatusResult[cloudbrain.Status] = 1
  100. // } else {
  101. // todayStatusResult[cloudbrain.Status] += 1
  102. // }
  103. // }
  104. // if _, ok := cloudBrainNum[cloudbrain.Cloudbrain.Type]; !ok {
  105. // cloudBrainNum[cloudbrain.Cloudbrain.Type] = 1
  106. // } else {
  107. // cloudBrainNum[cloudbrain.Cloudbrain.Type] += 1
  108. // }
  109. // if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  110. // cloudBrainOneDuration = cloudBrainOneDuration + cloudbrain.Cloudbrain.Duration
  111. // }
  112. // if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  113. // cloudBrainTwoDuration = cloudBrainTwoDuration + cloudbrain.Cloudbrain.Duration
  114. // }
  115. // if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  116. // intelligentNetDuration = intelligentNetDuration + cloudbrain.Cloudbrain.Duration
  117. // }
  118. // }
  119. // count = len(cloudbrains)
  120. // page += 1
  121. // }
  122. // statusNameList := []string{string(models.ModelArtsTrainJobCompleted), string(models.JobFailed), string(models.ModelArtsTrainJobInit),
  123. // string(models.JobRunning), string(models.ModelArtsStartFailed), string(models.JobStopped), string(models.JobSucceeded),
  124. // string(models.JobWaiting), string(models.ModelArtsTrainJobKilled)}
  125. // for _, v := range statusNameList {
  126. // if _, ok := todayStatusResult[v]; !ok {
  127. // todayStatusResult[v] = 0
  128. // }
  129. // }
  130. // cloudBrainTypeList := []int{0, 1, 2}
  131. // for _, v := range cloudBrainTypeList {
  132. // if _, ok := cloudBrainNum[v]; !ok {
  133. // cloudBrainNum[v] = 0
  134. // }
  135. // }
  136. // todayRunningCount := todayStatusResult[string(models.JobRunning)]
  137. // todayCompletedCount := todayStatusResult[string(models.ModelArtsTrainJobCompleted)] + todayStatusResult[string(models.JobFailed)] +
  138. // todayStatusResult[string(models.ModelArtsStartFailed)] + todayStatusResult[string(models.JobStopped)] + todayStatusResult[string(models.JobSucceeded)] + todayStatusResult[string(models.ModelArtsTrainJobKilled)]
  139. // todayWaitingCount := todayStatusResult[string(models.ModelArtsTrainJobInit)] + todayStatusResult[string(models.JobWaiting)]
  140. ctx.JSON(http.StatusOK, map[string]interface{}{
  141. "recordBeginTime": recordBeginTime,
  142. "updateTime": now.Unix(),
  143. // "cloudBrainNum": cloudBrainNum,
  144. // "cloudBrainOneDuration": cloudBrainOneDuration,
  145. // "cloudBrainTwoDuration": cloudBrainTwoDuration,
  146. // "intelligentNetDuration": intelligentNetDuration,
  147. "todayCreatorCount": todayCreatorCount,
  148. "creatorCount": creatorCount,
  149. "todayRunningCount": todayRunningCount,
  150. "todayCompletedCount": todayCompletedCount,
  151. "todayWaitingCount": todayWaitingCount,
  152. "todayNewJobCount": todayCloudbrainCount,
  153. "cloudbrainTypeCount": cloudbrainTypeCount,
  154. })
  155. }
  156. func GetOverviewDuration(ctx *context.Context) {
  157. recordCloudbrain, err := models.GetRecordBeginTime()
  158. if err != nil {
  159. log.Error("Can not get recordCloudbrain", err)
  160. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  161. return
  162. }
  163. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  164. now := time.Now()
  165. endTime := now
  166. page := 1
  167. pagesize := 10000
  168. count := pagesize
  169. worker_server_num := 1
  170. cardNum := 1
  171. // durationSum := int64(0)
  172. durationAllSum := int64(0)
  173. cardDuSum := int64(0)
  174. cloudBrainOneCardDuSum := int64(0)
  175. cloudBrainTwoCardDuSum := int64(0)
  176. c2NetCardDuSum := int64(0)
  177. cDNetCardDuSum := int64(0)
  178. cloudBrainOneDuration := int64(0)
  179. cloudBrainTwoDuration := int64(0)
  180. c2NetDuration := int64(0)
  181. cDCenterDuration := int64(0)
  182. for count == pagesize && count != 0 {
  183. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  184. ListOptions: models.ListOptions{
  185. Page: page,
  186. PageSize: pagesize,
  187. },
  188. Type: models.TypeCloudBrainAll,
  189. BeginTimeUnix: int64(recordBeginTime),
  190. EndTimeUnix: endTime.Unix(),
  191. })
  192. if err != nil {
  193. ctx.ServerError("Get cloudbrains failed:", err)
  194. return
  195. }
  196. models.LoadSpecs4CloudbrainInfo(cloudbrains)
  197. for _, cloudbrain := range cloudbrains {
  198. if cloudbrain.Cloudbrain.WorkServerNumber >= 1 {
  199. worker_server_num = cloudbrain.Cloudbrain.WorkServerNumber
  200. } else {
  201. worker_server_num = 1
  202. }
  203. if cloudbrain.Cloudbrain.Spec == nil {
  204. cardNum = 1
  205. } else {
  206. cardNum = cloudbrain.Cloudbrain.Spec.AccCardsNum
  207. }
  208. duration := cloudbrain.Duration
  209. durationSum := cloudbrain.Duration * int64(worker_server_num) * int64(cardNum)
  210. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  211. cloudBrainOneDuration += duration
  212. cloudBrainOneCardDuSum += durationSum
  213. } else if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  214. cloudBrainTwoDuration += duration
  215. cloudBrainTwoCardDuSum += durationSum
  216. } else if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  217. c2NetDuration += duration
  218. c2NetCardDuSum += durationSum
  219. } else if cloudbrain.Cloudbrain.Type == models.TypeCDCenter {
  220. cDCenterDuration += duration
  221. cDNetCardDuSum += durationSum
  222. }
  223. durationAllSum += duration
  224. cardDuSum += durationSum
  225. count = len(cloudbrains)
  226. page += 1
  227. }
  228. }
  229. ctx.JSON(http.StatusOK, map[string]interface{}{
  230. "cloudBrainOneCardDuSum": cloudBrainOneCardDuSum,
  231. "cloudBrainTwoCardDuSum": cloudBrainTwoCardDuSum,
  232. "c2NetCardDuSum": c2NetCardDuSum,
  233. "cDNetCardDuSum": cDNetCardDuSum,
  234. "cardDuSum": cardDuSum,
  235. "cloudBrainOneDuration": cloudBrainOneDuration,
  236. "cloudBrainTwoDuration": cloudBrainTwoDuration,
  237. "c2NetDuration": c2NetDuration,
  238. "cDCenterDuration": cDCenterDuration,
  239. "durationSum": durationAllSum,
  240. })
  241. }
  242. func GetAllCloudbrainsTrend(ctx *context.Context) {
  243. queryType := ctx.QueryTrim("type")
  244. now := time.Now()
  245. beginTimeStr := ctx.QueryTrim("beginTime")
  246. endTimeStr := ctx.QueryTrim("endTime")
  247. var beginTime time.Time
  248. var endTime time.Time
  249. dateCloudbrainNum := make([]DateCloudbrainNum, 0)
  250. var err error
  251. if queryType != "" {
  252. if queryType == "all" {
  253. recordCloudbrain, err := models.GetRecordBeginTime()
  254. if err != nil {
  255. log.Error("Can not get recordCloudbrain", err)
  256. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  257. return
  258. }
  259. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  260. beginTime = brainRecordBeginTime
  261. endTime = now
  262. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  263. if err != nil {
  264. log.Error("Can not query getMonthCloudbrainNum.", err)
  265. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  266. return
  267. }
  268. } else if queryType == "today" {
  269. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  270. // endTimeTemp = now
  271. endTime = beginTime.AddDate(0, 0, 1)
  272. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  273. if err != nil {
  274. log.Error("Can not query getDayCloudbrainNum.", err)
  275. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  276. return
  277. }
  278. } else if queryType == "yesterday" {
  279. beginTime = now.AddDate(0, 0, -1)
  280. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  281. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  282. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  283. if err != nil {
  284. log.Error("Can not query getDayCloudbrainNum.", err)
  285. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  286. return
  287. }
  288. } else if queryType == "last_7day" {
  289. beginTime = now.AddDate(0, 0, -6)
  290. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  291. endTime = now
  292. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  293. if err != nil {
  294. log.Error("Can not query getDayCloudbrainNum.", err)
  295. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  296. return
  297. }
  298. } else if queryType == "last_30day" {
  299. beginTime = now.AddDate(0, 0, -29)
  300. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  301. endTime = now
  302. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  303. if err != nil {
  304. log.Error("Can not query getDayCloudbrainNum.", err)
  305. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  306. return
  307. }
  308. } else if queryType == "current_month" {
  309. endTime = now
  310. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  311. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  312. if err != nil {
  313. log.Error("Can not query getDayCloudbrainNum.", err)
  314. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  315. return
  316. }
  317. } else if queryType == "current_year" {
  318. endTime = now
  319. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  320. // endTimeTemp = beginTime.AddDate(0, 1, 0)
  321. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  322. if err != nil {
  323. log.Error("Can not query getMonthCloudbrainNum.", err)
  324. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  325. return
  326. }
  327. } else if queryType == "last_month" {
  328. lastMonthTime := now.AddDate(0, -1, 0)
  329. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  330. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  331. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  332. if err != nil {
  333. log.Error("Can not query getDayCloudbrainNum.", err)
  334. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  335. return
  336. }
  337. }
  338. } else {
  339. if beginTimeStr == "" || endTimeStr == "" {
  340. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  341. recordCloudbrain, err := models.GetRecordBeginTime()
  342. if err != nil {
  343. log.Error("Can not get recordCloudbrain", err)
  344. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  345. return
  346. }
  347. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  348. beginTime = brainRecordBeginTime
  349. endTime = now
  350. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  351. if err != nil {
  352. log.Error("Can not query getMonthCloudbrainNum.", err)
  353. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  354. return
  355. }
  356. } else {
  357. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  358. if err != nil {
  359. log.Error("Can not ParseInLocation.", err)
  360. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  361. return
  362. }
  363. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  364. if err != nil {
  365. log.Error("Can not ParseInLocation.", err)
  366. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  367. return
  368. }
  369. if endTime.After(time.Now()) {
  370. endTime = time.Now()
  371. }
  372. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  373. if err != nil {
  374. log.Error("Can not query getDayCloudbrainNum.", err)
  375. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  376. return
  377. }
  378. }
  379. }
  380. ctx.JSON(http.StatusOK, map[string]interface{}{
  381. "timeCloudbrainNum": dateCloudbrainNum,
  382. })
  383. }
  384. func GetAllCloudbrainsTrendDetail(ctx *context.Context) {
  385. queryType := ctx.QueryTrim("type")
  386. now := time.Now()
  387. beginTimeStr := ctx.QueryTrim("beginTime")
  388. endTimeStr := ctx.QueryTrim("endTime")
  389. var beginTime time.Time
  390. var endTime time.Time
  391. var endTimeTemp time.Time
  392. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  393. var err error
  394. var count int
  395. if queryType != "" {
  396. if queryType == "all" {
  397. recordCloudbrain, err := models.GetRecordBeginTime()
  398. if err != nil {
  399. log.Error("Can not get recordCloudbrain", err)
  400. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  401. return
  402. }
  403. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  404. beginTime = brainRecordBeginTime
  405. endTime = now
  406. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  407. if err != nil {
  408. log.Error("Can not query getDayCloudbrainInfo.", err)
  409. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  410. return
  411. }
  412. } else if queryType == "today" {
  413. beginTime = now.AddDate(0, 0, 0)
  414. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  415. endTime = now
  416. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  417. if err != nil {
  418. log.Error("Can not query getDayCloudbrainInfo.", err)
  419. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  420. return
  421. }
  422. } else if queryType == "yesterday" {
  423. beginTime = now.AddDate(0, 0, -1)
  424. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  425. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  426. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  427. if err != nil {
  428. log.Error("Can not query getDayCloudbrainInfo.", err)
  429. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  430. return
  431. }
  432. } else if queryType == "last_7day" {
  433. beginTime = now.AddDate(0, 0, -6)
  434. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  435. endTime = now
  436. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), endTimeTemp.Day(), 0, 0, 0, 0, now.Location())
  437. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  438. if err != nil {
  439. log.Error("Can not query getDayCloudbrainInfo.", err)
  440. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  441. return
  442. }
  443. } else if queryType == "last_30day" {
  444. beginTime = now.AddDate(0, 0, -29)
  445. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  446. endTime = now
  447. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  448. if err != nil {
  449. log.Error("Can not query getDayCloudbrainInfo.", err)
  450. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  451. return
  452. }
  453. } else if queryType == "current_month" {
  454. endTime = now
  455. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  456. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  457. if err != nil {
  458. log.Error("Can not query getDayCloudbrainInfo.", err)
  459. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  460. return
  461. }
  462. } else if queryType == "current_year" {
  463. endTime = now
  464. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  465. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  466. if err != nil {
  467. log.Error("Can not query getDayCloudbrainInfo.", err)
  468. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  469. return
  470. }
  471. } else if queryType == "last_month" {
  472. lastMonthTime := now.AddDate(0, -1, 0)
  473. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  474. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  475. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  476. if err != nil {
  477. log.Error("Can not query getDayCloudbrainInfo.", err)
  478. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  479. return
  480. }
  481. }
  482. } else {
  483. if beginTimeStr == "" || endTimeStr == "" {
  484. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  485. recordCloudbrain, err := models.GetRecordBeginTime()
  486. if err != nil {
  487. log.Error("Can not get recordCloudbrain", err)
  488. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  489. return
  490. }
  491. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  492. beginTime = brainRecordBeginTime
  493. endTime = now
  494. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  495. if err != nil {
  496. log.Error("Can not query getDayCloudbrainInfo.", err)
  497. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  498. return
  499. }
  500. } else {
  501. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  502. if err != nil {
  503. log.Error("Can not ParseInLocation.", err)
  504. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  505. return
  506. }
  507. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  508. if err != nil {
  509. log.Error("Can not ParseInLocation.", err)
  510. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  511. return
  512. }
  513. if endTime.After(time.Now()) {
  514. endTime = time.Now()
  515. }
  516. endTimeTemp = beginTime.AddDate(0, 0, 1)
  517. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  518. if err != nil {
  519. log.Error("Can not query getDayCloudbrainInfo.", err)
  520. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  521. return
  522. }
  523. }
  524. }
  525. page := ctx.QueryInt("page")
  526. if page <= 0 {
  527. page = 1
  528. }
  529. pagesize := ctx.QueryInt("pagesize")
  530. if pagesize <= 0 {
  531. pagesize = 5
  532. }
  533. pageDateCloudbrainInfo := getPageDateCloudbrainInfo(dayCloudbrainInfo, page, pagesize)
  534. ctx.JSON(http.StatusOK, map[string]interface{}{
  535. "totalCount": count,
  536. "timeCloudbrainInfo": pageDateCloudbrainInfo,
  537. })
  538. }
  539. func getPageDateCloudbrainInfo(dateCloudbrainInfo []DateCloudbrainInfo, page int, pagesize int) []DateCloudbrainInfo {
  540. begin := (page - 1) * pagesize
  541. end := (page) * pagesize
  542. if begin > len(dateCloudbrainInfo)-1 {
  543. return nil
  544. }
  545. if end > len(dateCloudbrainInfo)-1 {
  546. return dateCloudbrainInfo[begin:]
  547. } else {
  548. return dateCloudbrainInfo[begin:end]
  549. }
  550. }
  551. func GetAllCloudbrainsPeriodDistribution(ctx *context.Context) {
  552. queryType := ctx.QueryTrim("type")
  553. beginTimeStr := ctx.QueryTrim("beginTime")
  554. endTimeStr := ctx.QueryTrim("endTime")
  555. recordCloudbrain, err := models.GetRecordBeginTime()
  556. if err != nil {
  557. log.Error("Can not get record begin time", err)
  558. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  559. return
  560. }
  561. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  562. beginTime, endTime, err := getCloudbrainTimePeroid(ctx, recordBeginTime)
  563. if err != nil {
  564. log.Error("Parameter is wrong", err)
  565. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.parameter_is_wrong"))
  566. return
  567. }
  568. cloudOneJobTypeRes := make(map[string]int)
  569. cloudTwoJobTypeRes := make(map[string]int)
  570. intelligentNetJobTypeRes := make(map[string]int)
  571. cDCenterJobTypeRes := make(map[string]int)
  572. cloudBrainPeriodNum := make(map[int]int)
  573. cloudBrainComputeResource := make(map[string]int)
  574. beginTimeTemp := beginTime.Unix()
  575. if queryType == "all" || (queryType == "" && (beginTimeStr == "" || endTimeStr == "")) {
  576. beginTimeTemp = int64(recordCloudbrain[0].Cloudbrain.CreatedUnix)
  577. }
  578. page := 1
  579. pagesize := 10000
  580. count := pagesize
  581. //Each time a maximum of 1000 pieces of data are detected to the memory, batch processing
  582. for count == pagesize && count != 0 {
  583. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  584. ListOptions: models.ListOptions{
  585. Page: page,
  586. PageSize: pagesize,
  587. },
  588. Type: models.TypeCloudBrainAll,
  589. BeginTimeUnix: beginTimeTemp,
  590. EndTimeUnix: endTime.Unix(),
  591. })
  592. if err != nil {
  593. ctx.ServerError("Get cloudbrains failed:", err)
  594. return
  595. }
  596. for _, cloudbrain := range cloudbrains {
  597. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  598. if _, ok := cloudOneJobTypeRes[cloudbrain.JobType]; !ok {
  599. cloudOneJobTypeRes[cloudbrain.JobType] = 1
  600. } else {
  601. cloudOneJobTypeRes[cloudbrain.JobType] += 1
  602. }
  603. }
  604. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  605. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  606. cloudTwoJobTypeRes[cloudbrain.JobType] = 1
  607. } else {
  608. cloudTwoJobTypeRes[cloudbrain.JobType] += 1
  609. }
  610. }
  611. if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  612. if _, ok := intelligentNetJobTypeRes[cloudbrain.JobType]; !ok {
  613. intelligentNetJobTypeRes[cloudbrain.JobType] = 1
  614. } else {
  615. intelligentNetJobTypeRes[cloudbrain.JobType] += 1
  616. }
  617. }
  618. if cloudbrain.Cloudbrain.Type == models.TypeCDCenter {
  619. if _, ok := cDCenterJobTypeRes[cloudbrain.JobType]; !ok {
  620. cDCenterJobTypeRes[cloudbrain.JobType] = 1
  621. } else {
  622. cDCenterJobTypeRes[cloudbrain.JobType] += 1
  623. }
  624. }
  625. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  626. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  627. } else {
  628. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  629. }
  630. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  631. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  632. } else {
  633. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  634. }
  635. }
  636. count = len(cloudbrains)
  637. page += 1
  638. }
  639. jobTypeList := []string{string(models.JobTypeDebug), string(models.JobTypeTrain), string(models.JobTypeInference), string(models.JobTypeBenchmark),
  640. string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet)}
  641. for _, v := range jobTypeList {
  642. if _, ok := cloudOneJobTypeRes[v]; !ok {
  643. cloudOneJobTypeRes[v] = 0
  644. }
  645. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  646. cloudTwoJobTypeRes[v] = 0
  647. }
  648. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  649. intelligentNetJobTypeRes[v] = 0
  650. }
  651. }
  652. cloudBrainTypeList := []int{0, 1, 2, 3}
  653. for _, v := range cloudBrainTypeList {
  654. if _, ok := cloudBrainPeriodNum[v]; !ok {
  655. cloudBrainPeriodNum[v] = 0
  656. }
  657. }
  658. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  659. for _, v := range ComputeResourceList {
  660. if _, ok := cloudBrainComputeResource[v]; !ok {
  661. cloudBrainComputeResource[v] = 0
  662. }
  663. }
  664. cloudOneJobTypeRes["EVALUATION"] = cloudOneJobTypeRes[string(models.JobTypeBenchmark)] + cloudOneJobTypeRes[string(models.JobTypeSnn4imagenet)] + cloudOneJobTypeRes[string(models.JobTypeBrainScore)]
  665. cloudTwoJobTypeRes["EVALUATION"] = cloudTwoJobTypeRes[string(models.JobTypeBenchmark)] + cloudTwoJobTypeRes[string(models.JobTypeSnn4imagenet)] + cloudTwoJobTypeRes[string(models.JobTypeBrainScore)]
  666. intelligentNetJobTypeRes["EVALUATION"] = intelligentNetJobTypeRes[string(models.JobTypeBenchmark)] + intelligentNetJobTypeRes[string(models.JobTypeSnn4imagenet)] + intelligentNetJobTypeRes[string(models.JobTypeBrainScore)]
  667. ctx.JSON(http.StatusOK, map[string]interface{}{
  668. "cloudOneJobTypeRes": cloudOneJobTypeRes,
  669. "cloudTwoJobTypeRes": cloudTwoJobTypeRes,
  670. "intelligentNetJobTypeRes": intelligentNetJobTypeRes,
  671. "cDCenterJobTypeRes": cDCenterJobTypeRes,
  672. "cloudBrainPeriodNum": cloudBrainPeriodNum,
  673. "cloudBrainComputeResource": cloudBrainComputeResource,
  674. })
  675. }
  676. func GetCloudbrainsStatusAnalysis(ctx *context.Context) {
  677. // recordCloudbrain, err := models.GetRecordBeginTime()
  678. // if err != nil {
  679. // log.Error("Can not get recordCloudbrain", err)
  680. // ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  681. // return
  682. // }
  683. // recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  684. // endTime := time.Now()
  685. // cloudBrainStatusResult := make(map[string]int)
  686. // cloudBrainStatusAnalysis := make(map[string]int)
  687. // totalCount := 0
  688. // page := 1
  689. // pagesize := 1000
  690. // count := pagesize
  691. // for count == pagesize && count != 0 {
  692. // cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  693. // ListOptions: models.ListOptions{
  694. // Page: page,
  695. // PageSize: pagesize,
  696. // },
  697. // Type: models.TypeCloudBrainAll,
  698. // BeginTimeUnix: int64(recordBeginTime),
  699. // EndTimeUnix: endTime.Unix(),
  700. // })
  701. // if err != nil {
  702. // ctx.ServerError("Get cloudbrains failed:", err)
  703. // return
  704. // }
  705. // for _, cloudbrain := range cloudbrains {
  706. // if _, ok := cloudBrainStatusResult[cloudbrain.Status]; !ok {
  707. // cloudBrainStatusResult[cloudbrain.Status] = 1
  708. // } else {
  709. // cloudBrainStatusResult[cloudbrain.Status] += 1
  710. // }
  711. // }
  712. // count = len(cloudbrains)
  713. // totalCount = totalCount + count
  714. // page += 1
  715. // }
  716. // var jobStatuses []string
  717. // jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  718. // string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  719. // string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  720. // jobStatusesCount := 0
  721. // for _, v := range jobStatuses {
  722. // if _, ok := cloudBrainStatusResult[v]; !ok {
  723. // cloudBrainStatusAnalysis[v] = 0
  724. // } else {
  725. // cloudBrainStatusAnalysis[v] = cloudBrainStatusResult[v]
  726. // }
  727. // jobStatusesCount = jobStatusesCount + cloudBrainStatusResult[v]
  728. // }
  729. // cloudBrainStatusAnalysis["OTHER"] = totalCount - jobStatusesCount
  730. cloudbrainStatusCount, err := models.GetCloudbrainStatusCount()
  731. log.Info("cloudbrainStatusCount:", cloudbrainStatusCount)
  732. if err != nil {
  733. log.Error("Can not query cloudbrainStatusCount.", err)
  734. return
  735. }
  736. ctx.JSON(http.StatusOK, map[string]interface{}{
  737. // "cloudBrainStatusResult": cloudBrainStatusAnalysis,
  738. "cloudbrainStatusCount": cloudbrainStatusCount,
  739. })
  740. }
  741. func GetCloudbrainsDetailData(ctx *context.Context) {
  742. recordCloudbrain, err := models.GetRecordBeginTime()
  743. if err != nil {
  744. log.Error("Can not get recordCloudbrain", err)
  745. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  746. return
  747. }
  748. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  749. endTime := time.Now()
  750. listType := ctx.Query("listType")
  751. jobType := ctx.Query("jobType")
  752. jobStatus := ctx.Query("jobStatus")
  753. cloudBrainType := ctx.QueryInt("Type")
  754. aiCenter := ctx.Query("aiCenter")
  755. needDeleteInfo := ctx.Query("needDeleteInfo")
  756. page := ctx.QueryInt("page")
  757. pageSize := ctx.QueryInt("pagesize")
  758. if page <= 0 {
  759. page = 1
  760. }
  761. if pageSize <= 0 {
  762. pageSize = 10
  763. }
  764. var jobTypes []string
  765. jobTypeNot := false
  766. if jobType == string(models.JobTypeBenchmark) {
  767. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet))
  768. } else if jobType != "all" && jobType != "" {
  769. jobTypes = append(jobTypes, jobType)
  770. }
  771. var jobStatuses []string
  772. jobStatusNot := false
  773. if jobStatus == "other" {
  774. jobStatusNot = true
  775. jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  776. string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  777. string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  778. } else if jobStatus != "all" && jobStatus != "" {
  779. jobStatuses = append(jobStatuses, jobStatus)
  780. }
  781. keyword := strings.Trim(ctx.Query("q"), " ")
  782. ciTasks, count, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  783. ListOptions: models.ListOptions{
  784. Page: page,
  785. PageSize: pageSize,
  786. },
  787. Keyword: keyword,
  788. Type: cloudBrainType,
  789. ComputeResource: listType,
  790. JobTypeNot: jobTypeNot,
  791. JobStatusNot: jobStatusNot,
  792. JobStatus: jobStatuses,
  793. JobTypes: jobTypes,
  794. NeedRepoInfo: true,
  795. BeginTimeUnix: int64(recordBeginTime),
  796. EndTimeUnix: endTime.Unix(),
  797. AiCenter: aiCenter,
  798. NeedDeleteInfo: needDeleteInfo,
  799. })
  800. if err != nil {
  801. ctx.ServerError("Get job failed:", err)
  802. return
  803. }
  804. models.LoadSpecs4CloudbrainInfo(ciTasks)
  805. nilTime := time.Time{}
  806. tasks := []models.TaskDetail{}
  807. for i, task := range ciTasks {
  808. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  809. var taskDetail models.TaskDetail
  810. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  811. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  812. taskDetail.JobName = ciTasks[i].JobName
  813. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  814. taskDetail.Status = ciTasks[i].Status
  815. taskDetail.JobType = ciTasks[i].JobType
  816. taskDetail.CreatedUnix = ciTasks[i].Cloudbrain.CreatedUnix
  817. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  818. taskDetail.StartTime = ciTasks[i].StartTime
  819. taskDetail.EndTime = ciTasks[i].EndTime
  820. taskDetail.ComputeResource = ciTasks[i].ComputeResource
  821. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  822. taskDetail.UserName = ciTasks[i].User.Name
  823. taskDetail.RepoID = ciTasks[i].RepoID
  824. if ciTasks[i].Repo != nil {
  825. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  826. taskDetail.RepoAlias = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Alias
  827. }
  828. if ciTasks[i].Cloudbrain.WorkServerNumber >= 1 {
  829. taskDetail.WorkServerNum = int64(ciTasks[i].Cloudbrain.WorkServerNumber)
  830. } else {
  831. taskDetail.WorkServerNum = 1
  832. }
  833. // taskDetail.CardNum, taskDetail.CardType, _ = repo.GetCloudbrainCardNumAndType(ciTasks[i].Cloudbrain)
  834. // if ciTasks[i].Cloudbrain.Spec != nil {
  835. // taskDetail.CardNum = ciTasks[i].Cloudbrain.Spec.AccCardsNum
  836. // taskDetail.CardType = ciTasks[i].Cloudbrain.Spec.AccCardType
  837. // taskDetail.AiCenter = ciTasks[i].Cloudbrain.Spec.AiCenterName
  838. // }
  839. // taskDetail.AiCenter = repo.GetCloudbrainAiCenter(ciTasks[i].Cloudbrain, ctx)
  840. // taskDetail.FlavorName, _ = repo.GetCloudbrainFlavorName(ciTasks[i].Cloudbrain)
  841. taskDetail.CardDuration = repo.GetCloudbrainCardDuration(ciTasks[i].Cloudbrain)
  842. taskDetail.WaitTime = repo.GetCloudbrainWaitTime(ciTasks[i].Cloudbrain)
  843. if ciTasks[i].Cloudbrain.DeletedAt != nilTime || ciTasks[i].Repo == nil {
  844. taskDetail.IsDelete = true
  845. } else {
  846. taskDetail.IsDelete = false
  847. }
  848. taskDetail.Spec = ciTasks[i].Spec
  849. tasks = append(tasks, taskDetail)
  850. }
  851. pager := context.NewPagination(int(count), pageSize, page, getTotalPage(count, pageSize))
  852. pager.SetDefaultParams(ctx)
  853. pager.AddParam(ctx, "listType", "ListType")
  854. ctx.JSON(http.StatusOK, map[string]interface{}{
  855. "Title": ctx.Tr("kanban.cloudBrains"),
  856. "Tasks": tasks,
  857. "Keyword": keyword,
  858. "pager": pager,
  859. "count": count,
  860. })
  861. }
  862. func getCloudbrainAiCenter(task models.Cloudbrain, ctx *context.Context) string {
  863. if task.Type == models.TypeCloudBrainOne {
  864. return ctx.Tr("repo.cloudbrain1")
  865. } else if task.Type == models.TypeCloudBrainTwo {
  866. return ctx.Tr("repo.cloudbrain2")
  867. } else if task.Type == models.TypeC2Net {
  868. return task.AiCenter
  869. }
  870. return ""
  871. }
  872. func GetCloudbrainsCreateHoursData(ctx *context.Context) {
  873. recordCloudbrain, err := models.GetRecordBeginTime()
  874. if err != nil {
  875. log.Error("Can not get record begin time", err)
  876. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  877. return
  878. }
  879. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  880. // recordBeginTime, _ := time.Parse("2006-01-02 15:04:05", recordTime)
  881. now := time.Now()
  882. queryType := ctx.QueryTrim("type")
  883. beginTimeStr := ctx.QueryTrim("beginTime")
  884. endTimeStr := ctx.QueryTrim("endTime")
  885. var beginTime time.Time
  886. var endTime time.Time
  887. createHourPeriodCount := make(map[string]interface{})
  888. if queryType != "" {
  889. if queryType == "all" {
  890. beginTime = recordBeginTime
  891. endTime = now.AddDate(0, 0, 1)
  892. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  893. } else if queryType == "today" {
  894. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  895. endTime = now.AddDate(0, 0, 1)
  896. } else if queryType == "yesterday" {
  897. beginTime = now.AddDate(0, 0, -1)
  898. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  899. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  900. } else if queryType == "current_week" {
  901. beginTime = now.AddDate(0, 0, -int(time.Now().Weekday())+1) //begin from monday
  902. endTime = now
  903. } else if queryType == "current_month" {
  904. beginTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  905. endTime = now.AddDate(0, 0, 1)
  906. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  907. } else if queryType == "monthly" {
  908. endTime = now
  909. beginTime = now.AddDate(0, -1, 0)
  910. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  911. } else if queryType == "current_year" {
  912. beginTime = time.Date(now.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  913. endTime = now.AddDate(0, 0, 1)
  914. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  915. } else if queryType == "last_month" {
  916. lastMonthTime := now.AddDate(0, -1, 0)
  917. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  918. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  919. } else if queryType == "last_7day" {
  920. beginTime = now.AddDate(0, 0, -6)
  921. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  922. endTime = now.AddDate(0, 0, 1)
  923. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  924. } else if queryType == "last_30day" {
  925. beginTime = now.AddDate(0, 0, -29)
  926. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  927. endTime = now.AddDate(0, 0, 1)
  928. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  929. }
  930. } else {
  931. if beginTimeStr == "" || endTimeStr == "" {
  932. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  933. beginTime = recordBeginTime
  934. endTime = now.AddDate(0, 0, 1)
  935. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  936. } else {
  937. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  938. if err != nil {
  939. log.Error("Can not ParseInLocation.", err)
  940. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  941. return
  942. }
  943. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  944. if err != nil {
  945. log.Error("Can not ParseInLocation.", err)
  946. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  947. return
  948. }
  949. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  950. }
  951. }
  952. dateBeginTime := beginTime.Format("2006-01-02")
  953. dateEndTime := endTime.Format("2006-01-02")
  954. createHourPeriodCount, err = models.GetCreateHourPeriodCount(dateBeginTime, dateEndTime)
  955. if err != nil {
  956. log.Error("Can not query hourPeriodCount.", err)
  957. ctx.Error(http.StatusBadRequest, ctx.Tr("hourPeriodCount_get_error"))
  958. return
  959. }
  960. runHourPeriodCount, err := models.GetRunHourPeriodCount(dateBeginTime, dateEndTime)
  961. if err != nil {
  962. log.Error("Can not query runHourPeriodCount.", err)
  963. ctx.Error(http.StatusBadRequest, ctx.Tr("runHourPeriodCount_get_error"))
  964. return
  965. }
  966. ctx.JSON(http.StatusOK, map[string]interface{}{
  967. "recordBeginTime": recordCloudbrain[0].Cloudbrain.CreatedUnix,
  968. "updateTime": now.Unix(),
  969. "createHourPeriodCount": createHourPeriodCount,
  970. "runHourPeriodCount": runHourPeriodCount,
  971. })
  972. }
  973. func GetWaittingTop(ctx *context.Context) {
  974. ciTasks, err := models.GetWaittingTop()
  975. if err != nil {
  976. log.Error("Can not get record begin time", err)
  977. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  978. return
  979. }
  980. tasks := []models.TaskDetail{}
  981. for i, task := range ciTasks {
  982. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  983. var taskDetail models.TaskDetail
  984. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  985. taskDetail.UserName = ciTasks[i].User.Name
  986. taskDetail.RepoID = ciTasks[i].RepoID
  987. if ciTasks[i].Repo != nil {
  988. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  989. }
  990. WaitTimeInt := time.Now().Unix() - ciTasks[i].Cloudbrain.CreatedUnix.AsTime().Unix()
  991. taskDetail.WaitTime = models.ConvertDurationToStr(WaitTimeInt)
  992. if WaitTimeInt < 0 {
  993. taskDetail.WaitTime = "00:00:00"
  994. }
  995. tasks = append(tasks, taskDetail)
  996. }
  997. ctx.JSON(http.StatusOK, map[string]interface{}{
  998. "tasks": tasks,
  999. })
  1000. }
  1001. func GetRunningTop(ctx *context.Context) {
  1002. ciTasks, err := models.GetRunningTop()
  1003. if err != nil {
  1004. log.Error("Can not get record begin time", err)
  1005. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1006. return
  1007. }
  1008. tasks := []models.TaskDetail{}
  1009. for i, task := range ciTasks {
  1010. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  1011. var taskDetail models.TaskDetail
  1012. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  1013. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  1014. taskDetail.UserName = ciTasks[i].User.Name
  1015. taskDetail.RepoID = ciTasks[i].RepoID
  1016. if ciTasks[i].Repo != nil {
  1017. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  1018. }
  1019. tasks = append(tasks, taskDetail)
  1020. }
  1021. ctx.JSON(http.StatusOK, map[string]interface{}{
  1022. "tasks": tasks,
  1023. })
  1024. }
  1025. func getCloudbrainCount(beginTime time.Time, endTime time.Time, cloudbrains []*models.CloudbrainInfo) (map[string]int, map[string]int, map[string]int, map[string]int, map[int]int, map[string]int) {
  1026. cloudOneJobTypeRes := make(map[string]int)
  1027. cloudTwoJobTypeRes := make(map[string]int)
  1028. intelligentNetJobTypeRes := make(map[string]int)
  1029. cDCenterJobTypeRes := make(map[string]int)
  1030. cloudBrainPeriodNum := make(map[int]int)
  1031. cloudBrainComputeResource := make(map[string]int)
  1032. for _, cloudbrain := range cloudbrains {
  1033. if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  1034. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  1035. if _, ok := cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType]; !ok {
  1036. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  1037. } else {
  1038. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  1039. }
  1040. }
  1041. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1042. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  1043. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  1044. } else {
  1045. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  1046. }
  1047. }
  1048. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  1049. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  1050. } else {
  1051. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  1052. }
  1053. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  1054. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  1055. } else {
  1056. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  1057. }
  1058. }
  1059. }
  1060. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  1061. for _, v := range ComputeResourceList {
  1062. if _, ok := cloudBrainComputeResource[v]; !ok {
  1063. cloudBrainComputeResource[v] = 0
  1064. }
  1065. }
  1066. jobTypeList := []string{"DEBUG", "BENCHMARK", "INFERENCE", "TRAIN", "SNN4IMAGENET", "BRAINSCORE"}
  1067. cloudBrainTypeList := []int{0, 1, 2, 3}
  1068. for _, v := range jobTypeList {
  1069. if _, ok := cloudOneJobTypeRes[v]; !ok {
  1070. cloudOneJobTypeRes[v] = 0
  1071. }
  1072. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  1073. cloudTwoJobTypeRes[v] = 0
  1074. }
  1075. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  1076. intelligentNetJobTypeRes[v] = 0
  1077. }
  1078. if _, ok := cDCenterJobTypeRes[v]; !ok {
  1079. cDCenterJobTypeRes[v] = 0
  1080. }
  1081. }
  1082. for _, v := range cloudBrainTypeList {
  1083. if _, ok := cloudBrainPeriodNum[v]; !ok {
  1084. cloudBrainPeriodNum[v] = 0
  1085. }
  1086. }
  1087. cloudBrainPeriodNum[-1] = cloudBrainPeriodNum[0] + cloudBrainPeriodNum[1] + cloudBrainPeriodNum[2]
  1088. return cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource
  1089. }
  1090. func getDayCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1091. var endTimeTemp time.Time
  1092. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1093. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1094. Type: models.TypeCloudBrainAll,
  1095. BeginTimeUnix: beginTime.Unix(),
  1096. EndTimeUnix: endTime.Unix(),
  1097. })
  1098. if err != nil {
  1099. log.Error("Get cloudbrains failed:", err)
  1100. return nil, err
  1101. }
  1102. dayCloudbrainNum := make([]DateCloudbrainNum, 0)
  1103. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1104. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1105. dayCloudbrainNum = append(dayCloudbrainNum, DateCloudbrainNum{
  1106. Date: beginTime.Format("2006/01/02"),
  1107. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1108. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1109. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1110. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1111. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1112. CloudBrainComputeResource: cloudBrainComputeResource,
  1113. })
  1114. if endTime.Before(endTimeTemp.AddDate(0, 0, 1)) && endTimeTemp.Before(endTime) {
  1115. beginTime = endTimeTemp
  1116. endTimeTemp = endTime
  1117. } else {
  1118. beginTime = endTimeTemp
  1119. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1120. }
  1121. }
  1122. return dayCloudbrainNum, nil
  1123. }
  1124. func getMonthCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1125. var endTimeTemp time.Time
  1126. now := time.Now()
  1127. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1128. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), 1, 0, 0, 0, 0, now.Location())
  1129. monthCloudbrainNum := make([]DateCloudbrainNum, 0)
  1130. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1131. Type: models.TypeCloudBrainAll,
  1132. BeginTimeUnix: beginTime.Unix(),
  1133. EndTimeUnix: endTime.Unix(),
  1134. })
  1135. if err != nil {
  1136. log.Error("Getcloudbrains failed:%v", err)
  1137. return nil, err
  1138. }
  1139. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1140. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1141. monthCloudbrainNum = append(monthCloudbrainNum, DateCloudbrainNum{
  1142. Date: beginTime.Format("2006/01"),
  1143. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1144. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1145. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1146. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1147. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1148. CloudBrainComputeResource: cloudBrainComputeResource,
  1149. })
  1150. if endTime.Before(endTimeTemp.AddDate(0, 1, 0)) && endTimeTemp.Before(endTime) {
  1151. beginTime = endTimeTemp
  1152. endTimeTemp = endTime
  1153. } else {
  1154. beginTime = endTimeTemp
  1155. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1156. }
  1157. }
  1158. return monthCloudbrainNum, nil
  1159. }
  1160. func getDayCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1161. now := time.Now()
  1162. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1163. if endTimeTemp.Equal(endTime) {
  1164. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1165. }
  1166. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1167. Type: models.TypeCloudBrainAll,
  1168. BeginTimeUnix: beginTime.Unix(),
  1169. EndTimeUnix: endTime.Unix(),
  1170. })
  1171. if err != nil {
  1172. log.Error("Getcloudbrains failed:%v", err)
  1173. return nil, 0, err
  1174. }
  1175. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1176. count := 0
  1177. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1178. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1179. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1180. Date: endTimeTemp.Format("2006/01/02"),
  1181. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1182. CloudBrainComputeResource: cloudBrainComputeResource,
  1183. })
  1184. endTime = endTimeTemp
  1185. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1186. count += 1
  1187. }
  1188. return dayCloudbrainInfo, count, nil
  1189. }
  1190. func getMonthCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1191. now := time.Now()
  1192. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1193. if endTimeTemp.Equal(endTime) {
  1194. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1195. }
  1196. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1197. Type: models.TypeCloudBrainAll,
  1198. BeginTimeUnix: beginTime.Unix(),
  1199. EndTimeUnix: endTime.Unix(),
  1200. })
  1201. if err != nil {
  1202. log.Error("Getcloudbrains failed:%v", err)
  1203. return nil, 0, err
  1204. }
  1205. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1206. count := 0
  1207. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) || (endTimeTemp.Before(beginTime) && beginTime.Before(endTime)) {
  1208. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1209. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1210. Date: endTimeTemp.Format("2006/01"),
  1211. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1212. CloudBrainComputeResource: cloudBrainComputeResource,
  1213. })
  1214. endTime = endTimeTemp
  1215. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1216. count += 1
  1217. }
  1218. return dayCloudbrainInfo, count, nil
  1219. }
  1220. func DownloadCloudBrainBoard(ctx *context.Context) {
  1221. page := 1
  1222. pageSize := 300
  1223. var cloudBrain = ctx.Tr("repo.cloudbrain")
  1224. fileName := getCloudbrainFileName(cloudBrain)
  1225. _, total, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1226. ListOptions: models.ListOptions{
  1227. Page: page,
  1228. PageSize: pageSize,
  1229. },
  1230. Type: models.TypeCloudBrainAll,
  1231. NeedRepoInfo: false,
  1232. })
  1233. if err != nil {
  1234. log.Warn("Can not get cloud brain info", err)
  1235. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  1236. return
  1237. }
  1238. totalPage := getTotalPage(total, pageSize)
  1239. f := excelize.NewFile()
  1240. index := f.NewSheet(cloudBrain)
  1241. f.DeleteSheet("Sheet1")
  1242. for k, v := range allCloudbrainHeader(ctx) {
  1243. f.SetCellValue(cloudBrain, k, v)
  1244. }
  1245. var row = 2
  1246. for i := 0; i < totalPage; i++ {
  1247. pageRecords, _, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1248. ListOptions: models.ListOptions{
  1249. Page: page,
  1250. PageSize: pageSize,
  1251. },
  1252. Type: models.TypeCloudBrainAll,
  1253. NeedRepoInfo: true,
  1254. })
  1255. if err != nil {
  1256. log.Warn("Can not get cloud brain info", err)
  1257. continue
  1258. }
  1259. for _, record := range pageRecords {
  1260. for k, v := range allCloudbrainValues(row, record, ctx) {
  1261. f.SetCellValue(cloudBrain, k, v)
  1262. }
  1263. row++
  1264. }
  1265. page++
  1266. }
  1267. f.SetActiveSheet(index)
  1268. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  1269. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  1270. f.WriteTo(ctx.Resp)
  1271. }
  1272. func getCloudbrainFileName(baseName string) string {
  1273. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  1274. }
  1275. func allCloudbrainHeader(ctx *context.Context) map[string]string {
  1276. return map[string]string{"A1": ctx.Tr("repo.cloudbrain_task"), "B1": ctx.Tr("repo.cloudbrain_type"), "C1": ctx.Tr("repo.modelarts.status"), "D1": ctx.Tr("repo.cloudbrain_task_type"),
  1277. "E1": ctx.Tr("repo.modelarts.createtime"), "F1": ctx.Tr("repo.modelarts.train_job.wait_time"), "G1": ctx.Tr("repo.modelarts.train_job.dura_time"),
  1278. "H1": ctx.Tr("cloudbrain.card_duration"),
  1279. "I1": ctx.Tr("repo.modelarts.train_job.start_time"), "J1": ctx.Tr("repo.modelarts.train_job.end_time"),
  1280. "K1": ctx.Tr("repo.modelarts.computing_resources"), "L1": ctx.Tr("cloudbrain.card_type"),
  1281. "M1": ctx.Tr("repo.grampus.train_job.ai_center"), "N1": ctx.Tr("cloudbrain.resource_specification"),
  1282. "O1": ctx.Tr("repo.cloudbrain_creator"), "P1": ctx.Tr("repo.repo_name"), "Q1": ctx.Tr("repo.cloudbrain_task_name"),
  1283. "R1": ctx.Tr("repo.modelarts.deletetime")}
  1284. }
  1285. func allCloudbrainValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  1286. return map[string]string{getCellName("A", row): rs.DisplayJobName, getCellName("B", row): getCloudbrainType(rs, ctx), getCellName("C", row): rs.Status, getCellName("D", row): rs.JobType,
  1287. getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT), getCellName("F", row): repo.GetCloudbrainWaitTime(rs.Cloudbrain),
  1288. getCellName("G", row): rs.TrainJobDuration, getCellName("H", row): repo.GetCloudbrainCardDuration(rs.Cloudbrain),
  1289. getCellName("I", row): getBrainStartTime(rs),
  1290. getCellName("J", row): getBrainEndTime(rs), getCellName("K", row): rs.ComputeResource, getCellName("L", row): getCloudbrainCardType(rs),
  1291. getCellName("M", row): repo.GetCloudbrainAiCenter(rs.Cloudbrain, ctx), getCellName("N", row): getCloudbrainFlavorName(rs),
  1292. getCellName("O", row): rs.Name, getCellName("P", row): getBrainRepo(rs),
  1293. getCellName("Q", row): rs.JobName, getCellName("R", row): getBrainDeleteTime(rs),
  1294. }
  1295. }
  1296. func getBrainRepo(rs *models.CloudbrainInfo) string {
  1297. if rs.Repo != nil {
  1298. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  1299. }
  1300. return ""
  1301. }
  1302. func getBrainStartTime(rs *models.CloudbrainInfo) string {
  1303. timeString := time.Unix(int64(rs.Cloudbrain.StartTime), 0).Format(CREATE_TIME_FORMAT)
  1304. if timeString != "1970/01/01 08:00:00" {
  1305. return timeString
  1306. } else {
  1307. return "0"
  1308. }
  1309. }
  1310. func getBrainEndTime(rs *models.CloudbrainInfo) string {
  1311. timeString := time.Unix(int64(rs.Cloudbrain.EndTime), 0).Format(CREATE_TIME_FORMAT)
  1312. if timeString != "1970/01/01 08:00:00" {
  1313. return timeString
  1314. } else {
  1315. return "0"
  1316. }
  1317. }
  1318. func getCloudbrainType(rs *models.CloudbrainInfo, ctx *context.Context) string {
  1319. if rs.Cloudbrain.Type == models.TypeCloudBrainOne {
  1320. return ctx.Tr("repo.cloudbrain1")
  1321. } else if rs.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1322. return ctx.Tr("repo.cloudbrain2")
  1323. } else if rs.Cloudbrain.Type == models.TypeC2Net {
  1324. return ctx.Tr("repo.intelligent_net")
  1325. } else {
  1326. return ctx.Tr("repo.cloudbrain_untype")
  1327. }
  1328. }
  1329. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  1330. _, cardType, _ := repo.GetCloudbrainCardNumAndType(rs.Cloudbrain)
  1331. return cardType
  1332. }
  1333. func getCloudbrainFlavorName(rs *models.CloudbrainInfo) string {
  1334. flavorName, _ := repo.GetCloudbrainFlavorName(rs.Cloudbrain)
  1335. return flavorName
  1336. }
  1337. func getBrainDeleteTime(rs *models.CloudbrainInfo) string {
  1338. nilTime := time.Time{}
  1339. if rs.Cloudbrain.DeletedAt != nilTime {
  1340. return rs.Cloudbrain.DeletedAt.Format("2006-01-02 15:04:05")
  1341. } else {
  1342. return ""
  1343. }
  1344. }
  1345. func getCloudbrainTimePeroid(ctx *context.Context, recordBeginTime time.Time) (time.Time, time.Time, error) {
  1346. queryType := ctx.QueryTrim("type")
  1347. beginTimeStr := ctx.QueryTrim("beginTime")
  1348. endTimeStr := ctx.QueryTrim("endTime")
  1349. now := time.Now()
  1350. var beginTime time.Time
  1351. var endTime time.Time
  1352. var err error
  1353. if queryType != "" {
  1354. if queryType == "all" {
  1355. beginTime = recordBeginTime
  1356. endTime = now
  1357. } else if queryType == "today" {
  1358. endTime = now
  1359. beginTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1360. } else if queryType == "yesterday" {
  1361. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1362. beginTime = endTime.AddDate(0, 0, -1)
  1363. } else if queryType == "last_7day" {
  1364. beginTime = now.AddDate(0, 0, -6)
  1365. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1366. endTime = now
  1367. } else if queryType == "last_30day" {
  1368. beginTime = now.AddDate(0, 0, -29)
  1369. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1370. endTime = now
  1371. } else if queryType == "current_month" {
  1372. endTime = now
  1373. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1374. } else if queryType == "monthly" {
  1375. endTime = now
  1376. beginTime = now.AddDate(0, -1, 1)
  1377. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1378. } else if queryType == "current_year" {
  1379. endTime = now
  1380. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1381. } else if queryType == "last_month" {
  1382. lastMonthTime := now.AddDate(0, -1, 0)
  1383. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1384. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1385. } else {
  1386. return now, now, fmt.Errorf("The value of type parameter is wrong.")
  1387. }
  1388. } else {
  1389. if beginTimeStr == "" || endTimeStr == "" {
  1390. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1391. beginTime = recordBeginTime
  1392. endTime = now
  1393. } else {
  1394. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1395. if err != nil {
  1396. return now, now, err
  1397. }
  1398. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1399. if err != nil {
  1400. return now, now, err
  1401. }
  1402. }
  1403. }
  1404. if beginTime.Before(recordBeginTime) {
  1405. beginTime = recordBeginTime
  1406. }
  1407. return beginTime, endTime, nil
  1408. }