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 54 kB

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