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