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

3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
3 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888
  1. package repo
  2. import (
  3. "fmt"
  4. "net/http"
  5. "net/url"
  6. "strconv"
  7. "strings"
  8. "time"
  9. "code.gitea.io/gitea/models"
  10. "code.gitea.io/gitea/modules/context"
  11. "code.gitea.io/gitea/modules/log"
  12. "code.gitea.io/gitea/routers/repo"
  13. cloudbrainService "code.gitea.io/gitea/services/cloudbrain"
  14. "github.com/360EntSecGroup-Skylar/excelize/v2"
  15. )
  16. type DateCloudbrainNum struct {
  17. Date string `json:"date"`
  18. CloudOneJobTypeRes map[string]int `json:"cloudOneJobTypeRes"`
  19. CloudTwoJobTypeRes map[string]int `json:"cloudTwoJobTypeRes"`
  20. IntelligentNetJobTypeRes map[string]int `json:"intelligentNetJobTypeRes"`
  21. CDCenterJobTypeRes map[string]int `json:"cDCenterJobTypeRes"`
  22. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  23. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  24. }
  25. type DateCloudbrainInfo struct {
  26. Date string `json:"date"`
  27. CloudBrainPeriodNum map[int]int `json:"cloudBrainPeriodNum"`
  28. CloudBrainComputeResource map[string]int `json:"cloudBrainComputeResource"`
  29. }
  30. type CloudbrainsStatusAnalysis struct {
  31. JobWaitingCount int64 `json:"jobWaitingCount"`
  32. JobRunningCount int64 `json:"jobRunningCount"`
  33. JobStoppedCount int64 `json:"jobStoppedCount"`
  34. JobCompletedCount int64 `json:"jobCompletedCount"`
  35. JobFailedCount int64 `json:"jobFailedCount"`
  36. JobKilledCount int64 `json:"jobKilledCount"`
  37. JobInitCount int64 `json:"jobInitCount"`
  38. }
  39. func GetAllCloudbrainsOverview(ctx *context.Context) {
  40. recordCloudbrain, err := models.GetRecordBeginTime()
  41. if err != nil {
  42. log.Error("Can not get recordCloudbrain", err)
  43. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  44. return
  45. }
  46. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  47. now := time.Now()
  48. beginTime := time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  49. endTime := now
  50. todayCreatorCount, err := models.GetTodayCreatorCount(beginTime, endTime)
  51. if err != nil {
  52. log.Error("Can not query todayCreatorCount.", err)
  53. return
  54. }
  55. cloudbrainTypeCount, err := models.GetCloudbrainTypeCount()
  56. log.Info("cloudbrainTypeCount:", cloudbrainTypeCount)
  57. if err != nil {
  58. log.Error("Can not query cloudbrainTypeCount.", err)
  59. return
  60. }
  61. cloudbrainTpyeDurationSum, err := models.GetCloudbrainTpyeDurationSum()
  62. log.Info("cloudbrainTpyeDurationSum:", cloudbrainTpyeDurationSum)
  63. if err != nil {
  64. log.Error("Can not query cloudbrainTpyeDurationSum.", err)
  65. return
  66. }
  67. todayCloudbrainCount, err := models.GetTodayCloudbrainCount(beginTime, endTime)
  68. log.Info("todayCloudbrainCount:", todayCloudbrainCount)
  69. if err != nil {
  70. log.Error("Can not query todayCloudbrainCount.", err)
  71. return
  72. }
  73. todayRunningCount, err := models.GetTodayRunningCount(beginTime, endTime)
  74. log.Info("todayRunningCount:", todayRunningCount)
  75. if err != nil {
  76. log.Error("Can not query todayRunningCount.", err)
  77. return
  78. }
  79. todayWaitingCount, err := models.GetTodayWaitingCount(beginTime, endTime)
  80. log.Info("todayWaittingCount:", todayWaitingCount)
  81. if err != nil {
  82. log.Error("Can not query todayWaitingCount.", err)
  83. return
  84. }
  85. todayCompletedCount := todayCloudbrainCount - todayRunningCount - todayWaitingCount
  86. log.Info("todayCompletedCount:", todayCompletedCount)
  87. creatorCount, err := models.GetCreatorCount()
  88. if err != nil {
  89. log.Error("Can not query creatorCount.", err)
  90. return
  91. }
  92. ctx.JSON(http.StatusOK, map[string]interface{}{
  93. "recordBeginTime": recordBeginTime,
  94. "updateTime": now.Unix(),
  95. "todayCreatorCount": todayCreatorCount,
  96. "creatorCount": creatorCount,
  97. "todayRunningCount": todayRunningCount,
  98. "todayCompletedCount": todayCompletedCount,
  99. "todayWaitingCount": todayWaitingCount,
  100. "todayNewJobCount": todayCloudbrainCount,
  101. "cloudbrainTypeCount": cloudbrainTypeCount,
  102. })
  103. }
  104. func GetOverviewDuration(ctx *context.Context) {
  105. recordCloudbrain, err := models.GetRecordBeginTime()
  106. if err != nil {
  107. log.Error("Can not get recordCloudbrain", err)
  108. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  109. return
  110. }
  111. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  112. now := time.Now()
  113. endTime := now
  114. worker_server_num := 1
  115. cardNum := 1
  116. durationAllSum := int64(0)
  117. cardDuSum := int64(0)
  118. cloudBrainOneCardDuSum := int64(0)
  119. cloudBrainTwoCardDuSum := int64(0)
  120. c2NetCardDuSum := int64(0)
  121. cDNetCardDuSum := int64(0)
  122. cloudBrainOneDuration := int64(0)
  123. cloudBrainTwoDuration := int64(0)
  124. c2NetDuration := int64(0)
  125. cDCenterDuration := int64(0)
  126. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  127. Type: models.TypeCloudBrainAll,
  128. BeginTimeUnix: int64(recordBeginTime),
  129. EndTimeUnix: endTime.Unix(),
  130. })
  131. if err != nil {
  132. ctx.ServerError("Get cloudbrains failed:", err)
  133. return
  134. }
  135. models.LoadSpecs4CloudbrainInfo(cloudbrains)
  136. for _, cloudbrain := range cloudbrains {
  137. if cloudbrain.Cloudbrain.WorkServerNumber >= 1 {
  138. worker_server_num = cloudbrain.Cloudbrain.WorkServerNumber
  139. } else {
  140. worker_server_num = 1
  141. }
  142. if cloudbrain.Cloudbrain.Spec == nil {
  143. cardNum = 1
  144. } else {
  145. cardNum = cloudbrain.Cloudbrain.Spec.AccCardsNum
  146. }
  147. duration := cloudbrain.Duration
  148. durationSum := cloudbrain.Duration * int64(worker_server_num) * int64(cardNum)
  149. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  150. cloudBrainOneDuration += duration
  151. cloudBrainOneCardDuSum += durationSum
  152. } else if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  153. cloudBrainTwoDuration += duration
  154. cloudBrainTwoCardDuSum += durationSum
  155. } else if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  156. c2NetDuration += duration
  157. c2NetCardDuSum += durationSum
  158. } else if cloudbrain.Cloudbrain.Type == models.TypeCDCenter {
  159. cDCenterDuration += duration
  160. cDNetCardDuSum += durationSum
  161. }
  162. durationAllSum += duration
  163. cardDuSum += durationSum
  164. }
  165. ctx.JSON(http.StatusOK, map[string]interface{}{
  166. "cloudBrainOneCardDuSum": cloudBrainOneCardDuSum,
  167. "cloudBrainTwoCardDuSum": cloudBrainTwoCardDuSum,
  168. "c2NetCardDuSum": c2NetCardDuSum,
  169. "cDNetCardDuSum": cDNetCardDuSum,
  170. "cardDuSum": cardDuSum,
  171. "cloudBrainOneDuration": cloudBrainOneDuration,
  172. "cloudBrainTwoDuration": cloudBrainTwoDuration,
  173. "c2NetDuration": c2NetDuration,
  174. "cDCenterDuration": cDCenterDuration,
  175. "durationSum": durationAllSum,
  176. })
  177. }
  178. func GetAllCloudbrainsTrend(ctx *context.Context) {
  179. queryType := ctx.QueryTrim("type")
  180. now := time.Now()
  181. beginTimeStr := ctx.QueryTrim("beginTime")
  182. endTimeStr := ctx.QueryTrim("endTime")
  183. var beginTime time.Time
  184. var endTime time.Time
  185. dateCloudbrainNum := make([]DateCloudbrainNum, 0)
  186. var err error
  187. if queryType != "" {
  188. if queryType == "all" {
  189. recordCloudbrain, err := models.GetRecordBeginTime()
  190. if err != nil {
  191. log.Error("Can not get recordCloudbrain", err)
  192. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  193. return
  194. }
  195. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  196. beginTime = brainRecordBeginTime
  197. endTime = now
  198. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  199. if err != nil {
  200. log.Error("Can not query getMonthCloudbrainNum.", err)
  201. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  202. return
  203. }
  204. } else if queryType == "today" {
  205. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  206. // endTimeTemp = now
  207. endTime = beginTime.AddDate(0, 0, 1)
  208. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  209. if err != nil {
  210. log.Error("Can not query getDayCloudbrainNum.", err)
  211. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  212. return
  213. }
  214. } else if queryType == "yesterday" {
  215. beginTime = now.AddDate(0, 0, -1)
  216. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  217. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  218. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  219. if err != nil {
  220. log.Error("Can not query getDayCloudbrainNum.", err)
  221. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  222. return
  223. }
  224. } else if queryType == "last_7day" {
  225. beginTime = now.AddDate(0, 0, -6)
  226. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  227. endTime = now
  228. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  229. if err != nil {
  230. log.Error("Can not query getDayCloudbrainNum.", err)
  231. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  232. return
  233. }
  234. } else if queryType == "last_30day" {
  235. beginTime = now.AddDate(0, 0, -29)
  236. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  237. endTime = now
  238. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  239. if err != nil {
  240. log.Error("Can not query getDayCloudbrainNum.", err)
  241. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  242. return
  243. }
  244. } else if queryType == "current_month" {
  245. endTime = now
  246. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  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_year" {
  254. endTime = now
  255. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  256. // endTimeTemp = beginTime.AddDate(0, 1, 0)
  257. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  258. if err != nil {
  259. log.Error("Can not query getMonthCloudbrainNum.", err)
  260. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  261. return
  262. }
  263. } else if queryType == "last_month" {
  264. lastMonthTime := now.AddDate(0, -1, 0)
  265. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  266. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  267. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  268. if err != nil {
  269. log.Error("Can not query getDayCloudbrainNum.", err)
  270. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  271. return
  272. }
  273. }
  274. } else {
  275. if beginTimeStr == "" || endTimeStr == "" {
  276. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  277. recordCloudbrain, err := models.GetRecordBeginTime()
  278. if err != nil {
  279. log.Error("Can not get recordCloudbrain", err)
  280. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  281. return
  282. }
  283. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  284. beginTime = brainRecordBeginTime
  285. endTime = now
  286. dateCloudbrainNum, err = getMonthCloudbrainNum(beginTime, endTime)
  287. if err != nil {
  288. log.Error("Can not query getMonthCloudbrainNum.", err)
  289. ctx.Error(http.StatusBadRequest, ctx.Tr("getMonthCloudbrainNum_get_error"))
  290. return
  291. }
  292. } else {
  293. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  294. if err != nil {
  295. log.Error("Can not ParseInLocation.", err)
  296. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  297. return
  298. }
  299. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  300. if err != nil {
  301. log.Error("Can not ParseInLocation.", err)
  302. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  303. return
  304. }
  305. if endTime.After(time.Now()) {
  306. endTime = time.Now()
  307. }
  308. dateCloudbrainNum, err = getDayCloudbrainNum(beginTime, endTime)
  309. if err != nil {
  310. log.Error("Can not query getDayCloudbrainNum.", err)
  311. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainNum_get_error"))
  312. return
  313. }
  314. }
  315. }
  316. ctx.JSON(http.StatusOK, map[string]interface{}{
  317. "timeCloudbrainNum": dateCloudbrainNum,
  318. })
  319. }
  320. func GetAllCloudbrainsTrendDetail(ctx *context.Context) {
  321. queryType := ctx.QueryTrim("type")
  322. now := time.Now()
  323. beginTimeStr := ctx.QueryTrim("beginTime")
  324. endTimeStr := ctx.QueryTrim("endTime")
  325. var beginTime time.Time
  326. var endTime time.Time
  327. var endTimeTemp time.Time
  328. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  329. var err error
  330. var count int
  331. if queryType != "" {
  332. if queryType == "all" {
  333. recordCloudbrain, err := models.GetRecordBeginTime()
  334. if err != nil {
  335. log.Error("Can not get recordCloudbrain", err)
  336. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  337. return
  338. }
  339. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  340. beginTime = brainRecordBeginTime
  341. endTime = now
  342. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  343. if err != nil {
  344. log.Error("Can not query getDayCloudbrainInfo.", err)
  345. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  346. return
  347. }
  348. } else if queryType == "today" {
  349. beginTime = now.AddDate(0, 0, 0)
  350. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  351. endTime = now
  352. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  353. if err != nil {
  354. log.Error("Can not query getDayCloudbrainInfo.", err)
  355. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  356. return
  357. }
  358. } else if queryType == "yesterday" {
  359. beginTime = now.AddDate(0, 0, -1)
  360. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  361. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  362. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  363. if err != nil {
  364. log.Error("Can not query getDayCloudbrainInfo.", err)
  365. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  366. return
  367. }
  368. } else if queryType == "last_7day" {
  369. beginTime = now.AddDate(0, 0, -6)
  370. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  371. endTime = now
  372. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), endTimeTemp.Day(), 0, 0, 0, 0, now.Location())
  373. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  374. if err != nil {
  375. log.Error("Can not query getDayCloudbrainInfo.", err)
  376. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  377. return
  378. }
  379. } else if queryType == "last_30day" {
  380. beginTime = now.AddDate(0, 0, -29)
  381. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  382. endTime = now
  383. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  384. if err != nil {
  385. log.Error("Can not query getDayCloudbrainInfo.", err)
  386. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  387. return
  388. }
  389. } else if queryType == "current_month" {
  390. endTime = now
  391. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  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_year" {
  399. endTime = now
  400. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  401. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(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 == "last_month" {
  408. lastMonthTime := now.AddDate(0, -1, 0)
  409. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  410. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  411. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  412. if err != nil {
  413. log.Error("Can not query getDayCloudbrainInfo.", err)
  414. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  415. return
  416. }
  417. }
  418. } else {
  419. if beginTimeStr == "" || endTimeStr == "" {
  420. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  421. recordCloudbrain, err := models.GetRecordBeginTime()
  422. if err != nil {
  423. log.Error("Can not get recordCloudbrain", err)
  424. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  425. return
  426. }
  427. brainRecordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix.AsTime()
  428. beginTime = brainRecordBeginTime
  429. endTime = now
  430. dayCloudbrainInfo, count, err = getMonthCloudbrainInfo(beginTime, endTime)
  431. if err != nil {
  432. log.Error("Can not query getDayCloudbrainInfo.", err)
  433. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  434. return
  435. }
  436. } else {
  437. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  438. if err != nil {
  439. log.Error("Can not ParseInLocation.", err)
  440. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  441. return
  442. }
  443. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  444. if err != nil {
  445. log.Error("Can not ParseInLocation.", err)
  446. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  447. return
  448. }
  449. if endTime.After(time.Now()) {
  450. endTime = time.Now()
  451. }
  452. endTimeTemp = beginTime.AddDate(0, 0, 1)
  453. dayCloudbrainInfo, count, err = getDayCloudbrainInfo(beginTime, endTime)
  454. if err != nil {
  455. log.Error("Can not query getDayCloudbrainInfo.", err)
  456. ctx.Error(http.StatusBadRequest, ctx.Tr("getDayCloudbrainInfo_get_error"))
  457. return
  458. }
  459. }
  460. }
  461. page := ctx.QueryInt("page")
  462. if page <= 0 {
  463. page = 1
  464. }
  465. pagesize := ctx.QueryInt("pagesize")
  466. if pagesize <= 0 {
  467. pagesize = 5
  468. }
  469. pageDateCloudbrainInfo := getPageDateCloudbrainInfo(dayCloudbrainInfo, page, pagesize)
  470. ctx.JSON(http.StatusOK, map[string]interface{}{
  471. "totalCount": count,
  472. "timeCloudbrainInfo": pageDateCloudbrainInfo,
  473. })
  474. }
  475. func getPageDateCloudbrainInfo(dateCloudbrainInfo []DateCloudbrainInfo, page int, pagesize int) []DateCloudbrainInfo {
  476. begin := (page - 1) * pagesize
  477. end := (page) * pagesize
  478. if begin > len(dateCloudbrainInfo)-1 {
  479. return nil
  480. }
  481. if end > len(dateCloudbrainInfo)-1 {
  482. return dateCloudbrainInfo[begin:]
  483. } else {
  484. return dateCloudbrainInfo[begin:end]
  485. }
  486. }
  487. func getPageDateCloudbrainDuration(dateUsageStatistic []models.DateUsageStatistic, page int, pagesize int) []models.DateUsageStatistic {
  488. begin := (page - 1) * pagesize
  489. end := (page) * pagesize
  490. if begin > len(dateUsageStatistic)-1 {
  491. return nil
  492. }
  493. if end > len(dateUsageStatistic)-1 {
  494. return dateUsageStatistic[begin:]
  495. } else {
  496. return dateUsageStatistic[begin:end]
  497. }
  498. }
  499. func GetAllCloudbrainsPeriodDistribution(ctx *context.Context) {
  500. queryType := ctx.QueryTrim("type")
  501. beginTimeStr := ctx.QueryTrim("beginTime")
  502. endTimeStr := ctx.QueryTrim("endTime")
  503. recordCloudbrain, err := models.GetRecordBeginTime()
  504. if err != nil {
  505. log.Error("Can not get record begin time", err)
  506. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  507. return
  508. }
  509. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  510. beginTime, endTime, err := getCloudbrainTimePeroid(ctx, recordBeginTime)
  511. if err != nil {
  512. log.Error("getCloudbrainTimePeroid error:", err)
  513. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.parameter_is_wrong"))
  514. return
  515. }
  516. cloudOneJobTypeRes := make(map[string]int)
  517. cloudTwoJobTypeRes := make(map[string]int)
  518. intelligentNetJobTypeRes := make(map[string]int)
  519. cDCenterJobTypeRes := make(map[string]int)
  520. cloudBrainPeriodNum := make(map[int]int)
  521. cloudBrainComputeResource := make(map[string]int)
  522. beginTimeTemp := beginTime.Unix()
  523. if queryType == "all" || (queryType == "" && (beginTimeStr == "" || endTimeStr == "")) {
  524. beginTimeTemp = int64(recordCloudbrain[0].Cloudbrain.CreatedUnix)
  525. }
  526. page := 1
  527. pagesize := 10000
  528. count := pagesize
  529. //Each time a maximum of 10000 pieces of data are detected to the memory, batch processing
  530. for count == pagesize && count != 0 {
  531. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  532. ListOptions: models.ListOptions{
  533. Page: page,
  534. PageSize: pagesize,
  535. },
  536. Type: models.TypeCloudBrainAll,
  537. BeginTimeUnix: beginTimeTemp,
  538. EndTimeUnix: endTime.Unix(),
  539. })
  540. if err != nil {
  541. ctx.ServerError("Get cloudbrains failed:", err)
  542. return
  543. }
  544. for _, cloudbrain := range cloudbrains {
  545. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  546. if _, ok := cloudOneJobTypeRes[cloudbrain.JobType]; !ok {
  547. cloudOneJobTypeRes[cloudbrain.JobType] = 1
  548. } else {
  549. cloudOneJobTypeRes[cloudbrain.JobType] += 1
  550. }
  551. }
  552. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  553. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  554. cloudTwoJobTypeRes[cloudbrain.JobType] = 1
  555. } else {
  556. cloudTwoJobTypeRes[cloudbrain.JobType] += 1
  557. }
  558. }
  559. if cloudbrain.Cloudbrain.Type == models.TypeC2Net {
  560. if _, ok := intelligentNetJobTypeRes[cloudbrain.JobType]; !ok {
  561. intelligentNetJobTypeRes[cloudbrain.JobType] = 1
  562. } else {
  563. intelligentNetJobTypeRes[cloudbrain.JobType] += 1
  564. }
  565. }
  566. if cloudbrain.Cloudbrain.Type == models.TypeCDCenter {
  567. if _, ok := cDCenterJobTypeRes[cloudbrain.JobType]; !ok {
  568. cDCenterJobTypeRes[cloudbrain.JobType] = 1
  569. } else {
  570. cDCenterJobTypeRes[cloudbrain.JobType] += 1
  571. }
  572. }
  573. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  574. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  575. } else {
  576. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  577. }
  578. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  579. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  580. } else {
  581. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  582. }
  583. }
  584. count = len(cloudbrains)
  585. page += 1
  586. }
  587. jobTypeList := []string{string(models.JobTypeDebug), string(models.JobTypeTrain), string(models.JobTypeInference), string(models.JobTypeBenchmark),
  588. string(models.JobTypeModelSafety), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet)}
  589. for _, v := range jobTypeList {
  590. if _, ok := cloudOneJobTypeRes[v]; !ok {
  591. cloudOneJobTypeRes[v] = 0
  592. }
  593. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  594. cloudTwoJobTypeRes[v] = 0
  595. }
  596. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  597. intelligentNetJobTypeRes[v] = 0
  598. }
  599. if _, ok := cDCenterJobTypeRes[v]; !ok {
  600. cDCenterJobTypeRes[v] = 0
  601. }
  602. }
  603. cloudBrainTypeList := []int{0, 1, 2, 3}
  604. for _, v := range cloudBrainTypeList {
  605. if _, ok := cloudBrainPeriodNum[v]; !ok {
  606. cloudBrainPeriodNum[v] = 0
  607. }
  608. }
  609. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  610. for _, v := range ComputeResourceList {
  611. if _, ok := cloudBrainComputeResource[v]; !ok {
  612. cloudBrainComputeResource[v] = 0
  613. }
  614. }
  615. cloudOneJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[0] - cloudOneJobTypeRes[string(models.JobTypeTrain)] - cloudOneJobTypeRes[string(models.JobTypeInference)] - cloudOneJobTypeRes[string(models.JobTypeDebug)]
  616. cloudTwoJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[1] - cloudTwoJobTypeRes[string(models.JobTypeTrain)] - cloudTwoJobTypeRes[string(models.JobTypeInference)] - cloudTwoJobTypeRes[string(models.JobTypeDebug)]
  617. intelligentNetJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[2] - intelligentNetJobTypeRes[string(models.JobTypeTrain)] - intelligentNetJobTypeRes[string(models.JobTypeInference)] - intelligentNetJobTypeRes[string(models.JobTypeDebug)]
  618. cDCenterJobTypeRes["EVALUATION"] = cloudBrainPeriodNum[3] - cDCenterJobTypeRes[string(models.JobTypeTrain)] - cDCenterJobTypeRes[string(models.JobTypeInference)] - cDCenterJobTypeRes[string(models.JobTypeDebug)]
  619. ctx.JSON(http.StatusOK, map[string]interface{}{
  620. "cloudOneJobTypeRes": cloudOneJobTypeRes,
  621. "cloudTwoJobTypeRes": cloudTwoJobTypeRes,
  622. "intelligentNetJobTypeRes": intelligentNetJobTypeRes,
  623. "cDCenterJobTypeRes": cDCenterJobTypeRes,
  624. "cloudBrainPeriodNum": cloudBrainPeriodNum,
  625. "cloudBrainComputeResource": cloudBrainComputeResource,
  626. })
  627. }
  628. func GetCloudbrainsStatusAnalysis(ctx *context.Context) {
  629. cloudbrainStatusCount, err := models.GetCloudbrainStatusCount()
  630. log.Info("cloudbrainStatusCount:", cloudbrainStatusCount)
  631. if err != nil {
  632. log.Error("Can not query cloudbrainStatusCount.", err)
  633. return
  634. }
  635. ctx.JSON(http.StatusOK, map[string]interface{}{
  636. "cloudbrainStatusCount": cloudbrainStatusCount,
  637. })
  638. }
  639. func GetCloudbrainsDetailData(ctx *context.Context) {
  640. recordCloudbrain, err := models.GetRecordBeginTime()
  641. if err != nil {
  642. log.Error("Can not get recordCloudbrain", err)
  643. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  644. return
  645. }
  646. recordBeginTime := recordCloudbrain[0].Cloudbrain.CreatedUnix
  647. endTime := time.Now()
  648. listType := ctx.Query("listType")
  649. jobType := ctx.Query("jobType")
  650. jobStatus := ctx.Query("jobStatus")
  651. cloudBrainType := ctx.QueryInt("Type")
  652. aiCenter := ctx.Query("aiCenter")
  653. needDeleteInfo := ctx.Query("needDeleteInfo")
  654. if cloudBrainType == models.TypeCloudBrainOne && aiCenter == models.AICenterOfCloudBrainOne {
  655. aiCenter = ""
  656. }
  657. if cloudBrainType == models.TypeCloudBrainTwo && aiCenter == models.AICenterOfCloudBrainTwo {
  658. aiCenter = ""
  659. }
  660. if cloudBrainType == models.TypeCDCenter && aiCenter == models.AICenterOfChengdu {
  661. aiCenter = ""
  662. }
  663. if cloudBrainType == models.TypeCloudBrainAll {
  664. if aiCenter == models.AICenterOfCloudBrainOne {
  665. cloudBrainType = models.TypeCloudBrainOne
  666. aiCenter = ""
  667. }
  668. if aiCenter == models.AICenterOfCloudBrainTwo {
  669. cloudBrainType = models.TypeCloudBrainTwo
  670. aiCenter = ""
  671. }
  672. if aiCenter == models.AICenterOfChengdu {
  673. cloudBrainType = models.TypeCDCenter
  674. aiCenter = ""
  675. }
  676. }
  677. page := ctx.QueryInt("page")
  678. pageSize := ctx.QueryInt("pagesize")
  679. if page <= 0 {
  680. page = 1
  681. }
  682. if pageSize <= 0 {
  683. pageSize = 10
  684. }
  685. var jobTypes []string
  686. jobTypeNot := false
  687. if jobType == string(models.JobTypeBenchmark) {
  688. jobTypes = append(jobTypes, string(models.JobTypeBenchmark), string(models.JobTypeModelSafety), string(models.JobTypeBrainScore), string(models.JobTypeSnn4imagenet))
  689. } else if jobType != "all" && jobType != "" {
  690. jobTypes = append(jobTypes, jobType)
  691. }
  692. var jobStatuses []string
  693. jobStatusNot := false
  694. if jobStatus == "other" {
  695. jobStatusNot = true
  696. jobStatuses = append(jobStatuses, string(models.ModelArtsTrainJobWaiting), string(models.ModelArtsTrainJobFailed), string(models.ModelArtsRunning), string(models.ModelArtsTrainJobCompleted),
  697. string(models.ModelArtsStarting), string(models.ModelArtsRestarting), string(models.ModelArtsStartFailed),
  698. string(models.ModelArtsStopping), string(models.ModelArtsStopped), string(models.JobSucceeded))
  699. } else if jobStatus != "all" && jobStatus != "" {
  700. jobStatuses = append(jobStatuses, jobStatus)
  701. }
  702. keyword := strings.Trim(ctx.Query("q"), " ")
  703. ciTasks, count, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  704. ListOptions: models.ListOptions{
  705. Page: page,
  706. PageSize: pageSize,
  707. },
  708. Keyword: keyword,
  709. Type: cloudBrainType,
  710. ComputeResource: listType,
  711. JobTypeNot: jobTypeNot,
  712. JobStatusNot: jobStatusNot,
  713. JobStatus: jobStatuses,
  714. JobTypes: jobTypes,
  715. NeedRepoInfo: true,
  716. BeginTimeUnix: int64(recordBeginTime),
  717. EndTimeUnix: endTime.Unix(),
  718. AiCenter: aiCenter,
  719. NeedDeleteInfo: needDeleteInfo,
  720. })
  721. if err != nil {
  722. ctx.ServerError("Get job failed:", err)
  723. return
  724. }
  725. models.LoadSpecs4CloudbrainInfo(ciTasks)
  726. nilTime := time.Time{}
  727. tasks := []models.TaskDetail{}
  728. for i, task := range ciTasks {
  729. task = cloudbrainService.UpdateCloudbrainAiCenter(task)
  730. var taskDetail models.TaskDetail
  731. taskDetail.ID = ciTasks[i].Cloudbrain.ID
  732. taskDetail.JobID = ciTasks[i].Cloudbrain.JobID
  733. taskDetail.JobName = ciTasks[i].JobName
  734. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  735. taskDetail.Status = ciTasks[i].Status
  736. taskDetail.JobType = ciTasks[i].JobType
  737. taskDetail.CreatedUnix = ciTasks[i].Cloudbrain.CreatedUnix
  738. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  739. taskDetail.StartTime = ciTasks[i].StartTime
  740. taskDetail.EndTime = ciTasks[i].EndTime
  741. taskDetail.ComputeResource = ciTasks[i].ComputeResource
  742. taskDetail.Type = ciTasks[i].Cloudbrain.Type
  743. taskDetail.UserName = ciTasks[i].User.Name
  744. taskDetail.RepoID = ciTasks[i].RepoID
  745. taskDetail.AiCenter = repo.GetAiCenterNameByCode(task.Cloudbrain.AiCenter)
  746. if ciTasks[i].Repo != nil {
  747. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  748. taskDetail.RepoAlias = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Alias
  749. }
  750. if ciTasks[i].Cloudbrain.WorkServerNumber >= 1 {
  751. taskDetail.WorkServerNum = int64(ciTasks[i].Cloudbrain.WorkServerNumber)
  752. } else {
  753. taskDetail.WorkServerNum = 1
  754. }
  755. taskDetail.CardDuration = repo.GetCloudbrainCardDuration(ciTasks[i].Cloudbrain)
  756. taskDetail.WaitTime = repo.GetCloudbrainWaitTime(ciTasks[i].Cloudbrain)
  757. if ciTasks[i].Cloudbrain.DeletedAt != nilTime || ciTasks[i].Repo == nil {
  758. taskDetail.IsDelete = true
  759. } else {
  760. taskDetail.IsDelete = false
  761. }
  762. taskDetail.Spec = ciTasks[i].Spec
  763. tasks = append(tasks, taskDetail)
  764. }
  765. pager := context.NewPagination(int(count), pageSize, page, getTotalPage(count, pageSize))
  766. pager.SetDefaultParams(ctx)
  767. pager.AddParam(ctx, "listType", "ListType")
  768. ctx.JSON(http.StatusOK, map[string]interface{}{
  769. "Title": ctx.Tr("kanban.cloudBrains"),
  770. "Tasks": tasks,
  771. "Keyword": keyword,
  772. "pager": pager,
  773. "count": count,
  774. })
  775. }
  776. func GetCloudbrainsCreateHoursData(ctx *context.Context) {
  777. recordCloudbrain, err := models.GetRecordBeginTime()
  778. if err != nil {
  779. log.Error("Can not get record begin time", err)
  780. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  781. return
  782. }
  783. recordBeginTime := time.Unix(int64(recordCloudbrain[0].Cloudbrain.CreatedUnix), 0)
  784. // recordBeginTime, _ := time.Parse("2006-01-02 15:04:05", recordTime)
  785. now := time.Now()
  786. queryType := ctx.QueryTrim("type")
  787. beginTimeStr := ctx.QueryTrim("beginTime")
  788. endTimeStr := ctx.QueryTrim("endTime")
  789. var beginTime time.Time
  790. var endTime time.Time
  791. createHourPeriodCount := make(map[string]interface{})
  792. if queryType != "" {
  793. if queryType == "all" {
  794. beginTime = recordBeginTime
  795. endTime = now.AddDate(0, 0, 1)
  796. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  797. } else if queryType == "today" {
  798. beginTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  799. endTime = now.AddDate(0, 0, 1)
  800. } else if queryType == "yesterday" {
  801. beginTime = now.AddDate(0, 0, -1)
  802. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  803. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  804. } else if queryType == "current_week" {
  805. beginTime = now.AddDate(0, 0, -int(time.Now().Weekday())+1) //begin from monday
  806. endTime = now
  807. } else if queryType == "current_month" {
  808. beginTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  809. endTime = now.AddDate(0, 0, 1)
  810. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  811. } else if queryType == "monthly" {
  812. endTime = now
  813. beginTime = now.AddDate(0, -1, 0)
  814. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  815. } else if queryType == "current_year" {
  816. beginTime = time.Date(now.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  817. endTime = now.AddDate(0, 0, 1)
  818. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  819. } else if queryType == "last_month" {
  820. lastMonthTime := now.AddDate(0, -1, 0)
  821. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  822. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  823. } else if queryType == "last_7day" {
  824. beginTime = now.AddDate(0, 0, -6)
  825. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  826. endTime = now.AddDate(0, 0, 1)
  827. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  828. } else if queryType == "last_30day" {
  829. beginTime = now.AddDate(0, 0, -29)
  830. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  831. endTime = now.AddDate(0, 0, 1)
  832. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  833. }
  834. } else {
  835. if beginTimeStr == "" || endTimeStr == "" {
  836. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  837. beginTime = recordBeginTime
  838. endTime = now.AddDate(0, 0, 1)
  839. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  840. } else {
  841. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  842. if err != nil {
  843. log.Error("Can not ParseInLocation.", err)
  844. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  845. return
  846. }
  847. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  848. if err != nil {
  849. log.Error("Can not ParseInLocation.", err)
  850. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  851. return
  852. }
  853. endTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  854. }
  855. }
  856. dateBeginTime := beginTime.Format("2006-01-02")
  857. dateEndTime := endTime.Format("2006-01-02")
  858. createHourPeriodCount, err = models.GetCreateHourPeriodCount(dateBeginTime, dateEndTime)
  859. if err != nil {
  860. log.Error("Can not query hourPeriodCount.", err)
  861. ctx.Error(http.StatusBadRequest, ctx.Tr("hourPeriodCount_get_error"))
  862. return
  863. }
  864. runHourPeriodCount, err := models.GetRunHourPeriodCount(dateBeginTime, dateEndTime)
  865. if err != nil {
  866. log.Error("Can not query runHourPeriodCount.", err)
  867. ctx.Error(http.StatusBadRequest, ctx.Tr("runHourPeriodCount_get_error"))
  868. return
  869. }
  870. ctx.JSON(http.StatusOK, map[string]interface{}{
  871. "recordBeginTime": recordCloudbrain[0].Cloudbrain.CreatedUnix,
  872. "updateTime": now.Unix(),
  873. "createHourPeriodCount": createHourPeriodCount,
  874. "runHourPeriodCount": runHourPeriodCount,
  875. })
  876. }
  877. func GetWaittingTop(ctx *context.Context) {
  878. ciTasks, err := models.GetWaittingTop()
  879. if err != nil {
  880. log.Error("Can not get record begin time", err)
  881. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  882. return
  883. }
  884. tasks := []models.TaskDetail{}
  885. for i, task := range ciTasks {
  886. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  887. var taskDetail models.TaskDetail
  888. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  889. taskDetail.UserName = ciTasks[i].User.Name
  890. taskDetail.RepoID = ciTasks[i].RepoID
  891. if ciTasks[i].Repo != nil {
  892. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  893. }
  894. WaitTimeInt := time.Now().Unix() - ciTasks[i].Cloudbrain.CreatedUnix.AsTime().Unix()
  895. taskDetail.WaitTime = models.ConvertDurationToStr(WaitTimeInt)
  896. if WaitTimeInt < 0 {
  897. taskDetail.WaitTime = "00:00:00"
  898. }
  899. tasks = append(tasks, taskDetail)
  900. }
  901. ctx.JSON(http.StatusOK, map[string]interface{}{
  902. "tasks": tasks,
  903. })
  904. }
  905. func GetRunningTop(ctx *context.Context) {
  906. ciTasks, err := models.GetRunningTop()
  907. if err != nil {
  908. log.Error("Can not get record begin time", err)
  909. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  910. return
  911. }
  912. tasks := []models.TaskDetail{}
  913. for i, task := range ciTasks {
  914. ciTasks[i].Cloudbrain.ComputeResource = task.ComputeResource
  915. var taskDetail models.TaskDetail
  916. taskDetail.DisplayJobName = ciTasks[i].DisplayJobName
  917. taskDetail.RunTime = ciTasks[i].Cloudbrain.TrainJobDuration
  918. taskDetail.UserName = ciTasks[i].User.Name
  919. taskDetail.RepoID = ciTasks[i].RepoID
  920. if ciTasks[i].Repo != nil {
  921. taskDetail.RepoName = ciTasks[i].Repo.OwnerName + "/" + ciTasks[i].Repo.Name
  922. }
  923. tasks = append(tasks, taskDetail)
  924. }
  925. ctx.JSON(http.StatusOK, map[string]interface{}{
  926. "tasks": tasks,
  927. })
  928. }
  929. 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) {
  930. cloudOneJobTypeRes := make(map[string]int)
  931. cloudTwoJobTypeRes := make(map[string]int)
  932. intelligentNetJobTypeRes := make(map[string]int)
  933. cDCenterJobTypeRes := make(map[string]int)
  934. cloudBrainPeriodNum := make(map[int]int)
  935. cloudBrainComputeResource := make(map[string]int)
  936. for _, cloudbrain := range cloudbrains {
  937. if int64(cloudbrain.Cloudbrain.CreatedUnix) >= beginTime.Unix() && int64(cloudbrain.Cloudbrain.CreatedUnix) < endTime.Unix() {
  938. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainOne {
  939. if _, ok := cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType]; !ok {
  940. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  941. } else {
  942. cloudOneJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  943. }
  944. }
  945. if cloudbrain.Cloudbrain.Type == models.TypeCloudBrainTwo {
  946. if _, ok := cloudTwoJobTypeRes[cloudbrain.JobType]; !ok {
  947. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] = 1
  948. } else {
  949. cloudTwoJobTypeRes[cloudbrain.Cloudbrain.JobType] += 1
  950. }
  951. }
  952. if _, ok := cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type]; !ok {
  953. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] = 1
  954. } else {
  955. cloudBrainPeriodNum[cloudbrain.Cloudbrain.Type] += 1
  956. }
  957. if _, ok := cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource]; !ok {
  958. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] = 1
  959. } else {
  960. cloudBrainComputeResource[cloudbrain.Cloudbrain.ComputeResource] += 1
  961. }
  962. }
  963. }
  964. ComputeResourceList := []string{"CPU/GPU", "NPU"}
  965. for _, v := range ComputeResourceList {
  966. if _, ok := cloudBrainComputeResource[v]; !ok {
  967. cloudBrainComputeResource[v] = 0
  968. }
  969. }
  970. jobTypeList := []string{"DEBUG", "BENCHMARK", "INFERENCE", "TRAIN", "SNN4IMAGENET", "BRAINSCORE"}
  971. cloudBrainTypeList := []int{0, 1, 2, 3}
  972. for _, v := range jobTypeList {
  973. if _, ok := cloudOneJobTypeRes[v]; !ok {
  974. cloudOneJobTypeRes[v] = 0
  975. }
  976. if _, ok := cloudTwoJobTypeRes[v]; !ok {
  977. cloudTwoJobTypeRes[v] = 0
  978. }
  979. if _, ok := intelligentNetJobTypeRes[v]; !ok {
  980. intelligentNetJobTypeRes[v] = 0
  981. }
  982. if _, ok := cDCenterJobTypeRes[v]; !ok {
  983. cDCenterJobTypeRes[v] = 0
  984. }
  985. }
  986. for _, v := range cloudBrainTypeList {
  987. if _, ok := cloudBrainPeriodNum[v]; !ok {
  988. cloudBrainPeriodNum[v] = 0
  989. }
  990. }
  991. cloudBrainPeriodNum[-1] = cloudBrainPeriodNum[0] + cloudBrainPeriodNum[1] + cloudBrainPeriodNum[2] + cloudBrainPeriodNum[3]
  992. return cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource
  993. }
  994. func getDayCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  995. var endTimeTemp time.Time
  996. endTimeTemp = beginTime.AddDate(0, 0, 1)
  997. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  998. Type: models.TypeCloudBrainAll,
  999. BeginTimeUnix: beginTime.Unix(),
  1000. EndTimeUnix: endTime.Unix(),
  1001. })
  1002. if err != nil {
  1003. log.Error("Get cloudbrains failed:", err)
  1004. return nil, err
  1005. }
  1006. dayCloudbrainNum := make([]DateCloudbrainNum, 0)
  1007. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1008. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1009. dayCloudbrainNum = append(dayCloudbrainNum, DateCloudbrainNum{
  1010. Date: beginTime.Format("2006/01/02"),
  1011. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1012. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1013. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1014. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1015. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1016. CloudBrainComputeResource: cloudBrainComputeResource,
  1017. })
  1018. if endTime.Before(endTimeTemp.AddDate(0, 0, 1)) && endTimeTemp.Before(endTime) {
  1019. beginTime = endTimeTemp
  1020. endTimeTemp = endTime
  1021. } else {
  1022. beginTime = endTimeTemp
  1023. endTimeTemp = beginTime.AddDate(0, 0, 1)
  1024. }
  1025. }
  1026. return dayCloudbrainNum, nil
  1027. }
  1028. func getMonthCloudbrainNum(beginTime time.Time, endTime time.Time) ([]DateCloudbrainNum, error) {
  1029. var endTimeTemp time.Time
  1030. now := time.Now()
  1031. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1032. endTimeTemp = time.Date(endTimeTemp.Year(), endTimeTemp.Month(), 1, 0, 0, 0, 0, now.Location())
  1033. monthCloudbrainNum := make([]DateCloudbrainNum, 0)
  1034. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1035. Type: models.TypeCloudBrainAll,
  1036. BeginTimeUnix: beginTime.Unix(),
  1037. EndTimeUnix: endTime.Unix(),
  1038. })
  1039. if err != nil {
  1040. log.Error("Getcloudbrains failed:%v", err)
  1041. return nil, err
  1042. }
  1043. for endTimeTemp.Before(endTime) || endTimeTemp.Equal(endTime) {
  1044. cloudOneJobTypeRes, cloudTwoJobTypeRes, intelligentNetJobTypeRes, cDCenterJobTypeRes, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(beginTime, endTimeTemp, cloudbrains)
  1045. monthCloudbrainNum = append(monthCloudbrainNum, DateCloudbrainNum{
  1046. Date: beginTime.Format("2006/01"),
  1047. CloudOneJobTypeRes: cloudOneJobTypeRes,
  1048. CloudTwoJobTypeRes: cloudTwoJobTypeRes,
  1049. IntelligentNetJobTypeRes: intelligentNetJobTypeRes,
  1050. CDCenterJobTypeRes: cDCenterJobTypeRes,
  1051. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1052. CloudBrainComputeResource: cloudBrainComputeResource,
  1053. })
  1054. if endTime.Before(endTimeTemp.AddDate(0, 1, 0)) && endTimeTemp.Before(endTime) {
  1055. beginTime = endTimeTemp
  1056. endTimeTemp = endTime
  1057. } else {
  1058. beginTime = endTimeTemp
  1059. endTimeTemp = beginTime.AddDate(0, 1, 0)
  1060. }
  1061. }
  1062. return monthCloudbrainNum, nil
  1063. }
  1064. func getDayCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1065. now := time.Now()
  1066. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1067. if endTimeTemp.Equal(endTime) {
  1068. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1069. }
  1070. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1071. Type: models.TypeCloudBrainAll,
  1072. BeginTimeUnix: beginTime.Unix(),
  1073. EndTimeUnix: endTime.Unix(),
  1074. })
  1075. if err != nil {
  1076. log.Error("Getcloudbrains failed:%v", err)
  1077. return nil, 0, err
  1078. }
  1079. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1080. count := 0
  1081. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1082. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1083. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1084. Date: endTimeTemp.Format("2006/01/02"),
  1085. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1086. CloudBrainComputeResource: cloudBrainComputeResource,
  1087. })
  1088. endTime = endTimeTemp
  1089. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1090. count += 1
  1091. }
  1092. return dayCloudbrainInfo, count, nil
  1093. }
  1094. func getMonthCloudbrainInfo(beginTime time.Time, endTime time.Time) ([]DateCloudbrainInfo, int, error) {
  1095. now := time.Now()
  1096. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1097. if endTimeTemp.Equal(endTime) {
  1098. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1099. }
  1100. cloudbrains, _, err := models.CloudbrainAllStatic(&models.CloudbrainsOptions{
  1101. Type: models.TypeCloudBrainAll,
  1102. BeginTimeUnix: beginTime.Unix(),
  1103. EndTimeUnix: endTime.Unix(),
  1104. })
  1105. if err != nil {
  1106. log.Error("Getcloudbrains failed:%v", err)
  1107. return nil, 0, err
  1108. }
  1109. dayCloudbrainInfo := make([]DateCloudbrainInfo, 0)
  1110. count := 0
  1111. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) || (endTimeTemp.Before(beginTime) && beginTime.Before(endTime)) {
  1112. _, _, _, _, cloudBrainPeriodNum, cloudBrainComputeResource := getCloudbrainCount(endTimeTemp, endTime, cloudbrains)
  1113. dayCloudbrainInfo = append(dayCloudbrainInfo, DateCloudbrainInfo{
  1114. Date: endTimeTemp.Format("2006/01"),
  1115. CloudBrainPeriodNum: cloudBrainPeriodNum,
  1116. CloudBrainComputeResource: cloudBrainComputeResource,
  1117. })
  1118. endTime = endTimeTemp
  1119. endTimeTemp = endTimeTemp.AddDate(0, -1, 0)
  1120. count += 1
  1121. }
  1122. return dayCloudbrainInfo, count, nil
  1123. }
  1124. func DownloadCloudBrainBoard(ctx *context.Context) {
  1125. page := 1
  1126. pageSize := 300
  1127. var cloudBrain = ctx.Tr("repo.cloudbrain")
  1128. fileName := getCloudbrainFileName(cloudBrain)
  1129. _, total, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1130. ListOptions: models.ListOptions{
  1131. Page: page,
  1132. PageSize: pageSize,
  1133. },
  1134. Type: models.TypeCloudBrainAll,
  1135. NeedRepoInfo: false,
  1136. })
  1137. if err != nil {
  1138. log.Warn("Can not get cloud brain info", err)
  1139. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.cloudbrain_query_fail"))
  1140. return
  1141. }
  1142. totalPage := getTotalPage(total, pageSize)
  1143. f := excelize.NewFile()
  1144. index := f.NewSheet(cloudBrain)
  1145. f.DeleteSheet("Sheet1")
  1146. for k, v := range allCloudbrainHeader(ctx) {
  1147. f.SetCellValue(cloudBrain, k, v)
  1148. }
  1149. var row = 2
  1150. for i := 0; i < totalPage; i++ {
  1151. pageRecords, _, err := models.CloudbrainAll(&models.CloudbrainsOptions{
  1152. ListOptions: models.ListOptions{
  1153. Page: page,
  1154. PageSize: pageSize,
  1155. },
  1156. Type: models.TypeCloudBrainAll,
  1157. NeedRepoInfo: true,
  1158. })
  1159. if err != nil {
  1160. log.Warn("Can not get cloud brain info", err)
  1161. continue
  1162. }
  1163. models.LoadSpecs4CloudbrainInfo(pageRecords)
  1164. for _, record := range pageRecords {
  1165. record = cloudbrainService.UpdateCloudbrainAiCenter(record)
  1166. record.Cloudbrain.AiCenter = repo.GetAiCenterNameByCode(record.Cloudbrain.AiCenter)
  1167. for k, v := range allCloudbrainValues(row, record, ctx) {
  1168. f.SetCellValue(cloudBrain, k, v)
  1169. }
  1170. row++
  1171. }
  1172. page++
  1173. }
  1174. f.SetActiveSheet(index)
  1175. ctx.Resp.Header().Set("Content-Disposition", "attachment; filename="+url.QueryEscape(fileName))
  1176. ctx.Resp.Header().Set("Content-Type", "application/octet-stream")
  1177. f.WriteTo(ctx.Resp)
  1178. }
  1179. func getCloudbrainFileName(baseName string) string {
  1180. return baseName + "_" + time.Now().Format(EXCEL_DATE_FORMAT) + ".xlsx"
  1181. }
  1182. func allCloudbrainHeader(ctx *context.Context) map[string]string {
  1183. 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"),
  1184. "E1": ctx.Tr("repo.modelarts.createtime"), "F1": ctx.Tr("repo.modelarts.train_job.wait_time"), "G1": ctx.Tr("repo.modelarts.train_job.dura_time"),
  1185. "H1": ctx.Tr("cloudbrain.card_duration"),
  1186. "I1": ctx.Tr("repo.modelarts.train_job.start_time"), "J1": ctx.Tr("repo.modelarts.train_job.end_time"),
  1187. "K1": ctx.Tr("repo.modelarts.computing_resources"), "L1": ctx.Tr("cloudbrain.card_type"),
  1188. "M1": ctx.Tr("repo.modelarts.train_job.amount_of_compute_node"), "N1": ctx.Tr("repo.grampus.train_job.ai_center"),
  1189. "O1": ctx.Tr("cloudbrain.resource_specification"), "P1": ctx.Tr("repo.cloudbrain_creator"), "Q1": ctx.Tr("repo.repo_name"),
  1190. "R1": ctx.Tr("repo.cloudbrain_task_name"), "S1": ctx.Tr("repo.modelarts.deletetime")}
  1191. }
  1192. func allCloudbrainValues(row int, rs *models.CloudbrainInfo, ctx *context.Context) map[string]string {
  1193. 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,
  1194. getCellName("E", row): time.Unix(int64(rs.Cloudbrain.CreatedUnix), 0).Format(CREATE_TIME_FORMAT), getCellName("F", row): repo.GetCloudbrainWaitTime(rs.Cloudbrain),
  1195. getCellName("G", row): rs.TrainJobDuration, getCellName("H", row): repo.GetCloudbrainCardDuration(rs.Cloudbrain),
  1196. getCellName("I", row): getBrainStartTime(rs),
  1197. getCellName("J", row): getBrainEndTime(rs), getCellName("K", row): rs.ComputeResource, getCellName("L", row): getCloudbrainCardType(rs),
  1198. getCellName("M", row): getWorkServerNum(rs), getCellName("N", row): rs.Cloudbrain.AiCenter,
  1199. getCellName("O", row): getCloudbrainFlavorName(rs), getCellName("P", row): rs.Name,
  1200. getCellName("Q", row): getBrainRepo(rs), getCellName("R", row): rs.JobName, getCellName("S", row): getBrainDeleteTime(rs),
  1201. }
  1202. }
  1203. func getWorkServerNum(rs *models.CloudbrainInfo) string {
  1204. if rs.Cloudbrain.WorkServerNumber >= 1 {
  1205. return fmt.Sprint(rs.Cloudbrain.WorkServerNumber)
  1206. } else {
  1207. return "1"
  1208. }
  1209. }
  1210. func getBrainRepo(rs *models.CloudbrainInfo) string {
  1211. if rs.Repo != nil {
  1212. return rs.Repo.OwnerName + "/" + rs.Repo.Alias
  1213. }
  1214. return ""
  1215. }
  1216. func getBrainStartTime(rs *models.CloudbrainInfo) string {
  1217. timeString := time.Unix(int64(rs.Cloudbrain.StartTime), 0).Format(CREATE_TIME_FORMAT)
  1218. if timeString != "1970/01/01 08:00:00" {
  1219. return timeString
  1220. } else {
  1221. return "0"
  1222. }
  1223. }
  1224. func getBrainEndTime(rs *models.CloudbrainInfo) string {
  1225. timeString := time.Unix(int64(rs.Cloudbrain.EndTime), 0).Format(CREATE_TIME_FORMAT)
  1226. if timeString != "1970/01/01 08:00:00" {
  1227. return timeString
  1228. } else {
  1229. return "0"
  1230. }
  1231. }
  1232. func getCloudbrainType(rs *models.CloudbrainInfo, ctx *context.Context) string {
  1233. if rs.Cloudbrain.Type == models.TypeCloudBrainOne {
  1234. return ctx.Tr("repo.cloudbrain1")
  1235. } else if rs.Cloudbrain.Type == models.TypeCloudBrainTwo {
  1236. return ctx.Tr("repo.cloudbrain2")
  1237. } else if rs.Cloudbrain.Type == models.TypeC2Net {
  1238. return ctx.Tr("repo.intelligent_net")
  1239. } else {
  1240. return ctx.Tr("repo.cloudbrain_untype")
  1241. }
  1242. }
  1243. func getCloudbrainCardType(rs *models.CloudbrainInfo) string {
  1244. if rs.Cloudbrain.Spec != nil {
  1245. return rs.Cloudbrain.Spec.AccCardType
  1246. } else {
  1247. return ""
  1248. }
  1249. }
  1250. func getCloudbrainFlavorName(rs *models.CloudbrainInfo) string {
  1251. flavorName := repo.GetCloudbrainFlavorName(rs.Cloudbrain)
  1252. return flavorName
  1253. }
  1254. func getBrainDeleteTime(rs *models.CloudbrainInfo) string {
  1255. nilTime := time.Time{}
  1256. if rs.Cloudbrain.DeletedAt != nilTime {
  1257. return rs.Cloudbrain.DeletedAt.Format("2006-01-02 15:04:05")
  1258. } else {
  1259. return ""
  1260. }
  1261. }
  1262. func getCloudbrainTimePeroid(ctx *context.Context, recordBeginTime time.Time) (time.Time, time.Time, error) {
  1263. queryType := ctx.QueryTrim("type")
  1264. beginTimeStr := ctx.QueryTrim("beginTime")
  1265. endTimeStr := ctx.QueryTrim("endTime")
  1266. now := time.Now()
  1267. var beginTime time.Time
  1268. var endTime time.Time
  1269. var err error
  1270. if queryType != "" {
  1271. if queryType == "all" {
  1272. beginTime = recordBeginTime
  1273. endTime = now
  1274. } else if queryType == "today" {
  1275. endTime = now
  1276. beginTime = time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1277. } else if queryType == "yesterday" {
  1278. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1279. beginTime = endTime.AddDate(0, 0, -1)
  1280. } else if queryType == "last_7day" {
  1281. beginTime = now.AddDate(0, 0, -6)
  1282. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1283. endTime = now
  1284. } else if queryType == "last_30day" {
  1285. beginTime = now.AddDate(0, 0, -29)
  1286. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1287. endTime = now
  1288. } else if queryType == "current_month" {
  1289. endTime = now
  1290. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1291. } else if queryType == "monthly" {
  1292. endTime = now
  1293. beginTime = now.AddDate(0, -1, 1)
  1294. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1295. } else if queryType == "current_year" {
  1296. endTime = now
  1297. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1298. } else if queryType == "last_month" {
  1299. lastMonthTime := now.AddDate(0, -1, 0)
  1300. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1301. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1302. } else {
  1303. return now, now, fmt.Errorf("The value of type parameter is wrong.")
  1304. }
  1305. } else {
  1306. if beginTimeStr == "" || endTimeStr == "" {
  1307. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1308. beginTime = recordBeginTime
  1309. endTime = now
  1310. } else {
  1311. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1312. if err != nil {
  1313. return now, now, err
  1314. }
  1315. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1316. if err != nil {
  1317. return now, now, err
  1318. }
  1319. }
  1320. }
  1321. if beginTime.Before(recordBeginTime) {
  1322. beginTime = recordBeginTime
  1323. }
  1324. return beginTime, endTime, nil
  1325. }
  1326. func GetCloudbrainResourceOverview(ctx *context.Context) {
  1327. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1328. if err != nil {
  1329. log.Error("Can not get GetDurationRecordBeginTime", err)
  1330. return
  1331. }
  1332. recordBeginTime := recordCloudbrainDuration[0].DateTime - 1*60*60
  1333. recordUpdateTime := time.Now().Unix()
  1334. resourceQueues, err := models.GetCanUseCardInfo()
  1335. if err != nil {
  1336. log.Info("GetCanUseCardInfo err: %v", err)
  1337. return
  1338. }
  1339. OpenIResourceDetail := []models.ResourceDetail{}
  1340. C2NetResourceDetail := []models.ResourceDetail{}
  1341. for _, resourceQueue := range resourceQueues {
  1342. if resourceQueue.Cluster == models.OpenICluster {
  1343. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode)
  1344. var resourceDetail models.ResourceDetail
  1345. resourceDetail.QueueCode = resourceQueue.QueueCode
  1346. resourceDetail.Cluster = resourceQueue.Cluster
  1347. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1348. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1349. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1350. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1351. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1352. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1353. OpenIResourceDetail = append(OpenIResourceDetail, resourceDetail)
  1354. }
  1355. if resourceQueue.Cluster == models.C2NetCluster {
  1356. aiCenterName := repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode)
  1357. var resourceDetail models.ResourceDetail
  1358. resourceDetail.QueueCode = resourceQueue.QueueCode
  1359. resourceDetail.Cluster = resourceQueue.Cluster
  1360. resourceDetail.AiCenterCode = resourceQueue.AiCenterCode
  1361. resourceDetail.AiCenterName = resourceQueue.AiCenterCode + "/" + aiCenterName
  1362. resourceDetail.ComputeResource = resourceQueue.ComputeResource
  1363. resourceDetail.AccCardType = resourceQueue.AccCardType + "(" + resourceQueue.ComputeResource + ")"
  1364. resourceDetail.CardsTotalNum = resourceQueue.CardsTotalNum
  1365. resourceDetail.IsAutomaticSync = resourceQueue.IsAutomaticSync
  1366. C2NetResourceDetail = append(C2NetResourceDetail, resourceDetail)
  1367. }
  1368. }
  1369. openIResourceNum := make(map[string]map[string]int)
  1370. for _, openIResourceDetail := range OpenIResourceDetail {
  1371. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName]; !ok {
  1372. openIResourceNum[openIResourceDetail.AiCenterName] = make(map[string]int)
  1373. }
  1374. if _, ok := openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType]; !ok {
  1375. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] = openIResourceDetail.CardsTotalNum
  1376. } else {
  1377. openIResourceNum[openIResourceDetail.AiCenterName][openIResourceDetail.AccCardType] += openIResourceDetail.CardsTotalNum
  1378. }
  1379. }
  1380. c2NetResourceNum := make(map[string]map[string]int)
  1381. for _, c2NetResourceDetail := range C2NetResourceDetail {
  1382. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName]; !ok {
  1383. c2NetResourceNum[c2NetResourceDetail.AiCenterName] = make(map[string]int)
  1384. }
  1385. if _, ok := c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType]; !ok {
  1386. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] = c2NetResourceDetail.CardsTotalNum
  1387. } else {
  1388. c2NetResourceNum[c2NetResourceDetail.AiCenterName][c2NetResourceDetail.AccCardType] += c2NetResourceDetail.CardsTotalNum
  1389. }
  1390. }
  1391. ctx.JSON(http.StatusOK, map[string]interface{}{
  1392. "openI": openIResourceNum,
  1393. "c2Net": c2NetResourceNum,
  1394. "recordUpdateTime": recordUpdateTime,
  1395. "recordBeginTime": recordBeginTime,
  1396. })
  1397. }
  1398. func GetCloudbrainResourceUsageDetail(ctx *context.Context) {
  1399. aiCenterCode := ctx.QueryTrim("aiCenterCode")
  1400. if aiCenterCode == "" {
  1401. aiCenterCode = models.AICenterOfCloudBrainOne
  1402. }
  1403. beginTime, endTime := getBeginAndEndTime(ctx)
  1404. dayCloudbrainDuration, count, err := getDayCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1405. if err != nil {
  1406. log.Error("Can not query dayCloudbrainDuration.", err)
  1407. return
  1408. }
  1409. hourCloudbrainDuration, err := getHourCloudbrainDuration(beginTime, endTime, aiCenterCode)
  1410. if err != nil {
  1411. log.Error("Can not query hourCloudbrainDuration.", err)
  1412. return
  1413. }
  1414. page := ctx.QueryInt("page")
  1415. if page <= 0 {
  1416. page = 1
  1417. }
  1418. pagesize := ctx.QueryInt("pagesize")
  1419. if pagesize <= 0 {
  1420. pagesize = 36500
  1421. }
  1422. pageDateCloudbrainDuration := getPageDateCloudbrainDuration(dayCloudbrainDuration, page, pagesize)
  1423. ctx.JSON(http.StatusOK, map[string]interface{}{
  1424. "totalCount": count,
  1425. "pageDateCloudbrainDuration": pageDateCloudbrainDuration,
  1426. "hourCloudbrainDuration": hourCloudbrainDuration,
  1427. })
  1428. }
  1429. func GetDurationRateStatistic(ctx *context.Context) {
  1430. beginTime, endTime := getBeginAndEndTime(ctx)
  1431. OpenIDurationRate, C2NetDurationRate, totalUsageRate := getDurationStatistic(beginTime, endTime)
  1432. ctx.JSON(http.StatusOK, map[string]interface{}{
  1433. "openIDurationRate": OpenIDurationRate,
  1434. "c2NetDurationRate": C2NetDurationRate,
  1435. "totalUsageRate": totalUsageRate,
  1436. })
  1437. }
  1438. func CloudbrainDurationStatisticForTest(ctx *context.Context) {
  1439. repo.CloudbrainDurationStatisticHour()
  1440. ctx.JSON(http.StatusOK, map[string]interface{}{
  1441. "message": 0,
  1442. })
  1443. }
  1444. func getBeginAndEndTime(ctx *context.Context) (time.Time, time.Time) {
  1445. queryType := ctx.QueryTrim("type")
  1446. now := time.Now()
  1447. beginTimeStr := ctx.QueryTrim("beginTime")
  1448. endTimeStr := ctx.QueryTrim("endTime")
  1449. var beginTime time.Time
  1450. var endTime time.Time
  1451. var err error
  1452. if queryType != "" {
  1453. if queryType == "all" {
  1454. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1455. if err != nil {
  1456. log.Error("Can not get GetDurationRecordBeginTime", err)
  1457. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1458. return beginTime, endTime
  1459. }
  1460. brainRecordBeginTime := recordCloudbrainDuration[0].DateTime.AsTime()
  1461. beginTime = brainRecordBeginTime
  1462. endTime = now
  1463. } else if queryType == "today" {
  1464. beginTime = now.AddDate(0, 0, 0)
  1465. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1466. endTime = now
  1467. } else if queryType == "yesterday" {
  1468. beginTime = now.AddDate(0, 0, -1)
  1469. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1470. endTime = time.Date(now.Year(), now.Month(), now.Day(), 0, 0, 0, 0, now.Location())
  1471. } else if queryType == "last_7day" {
  1472. beginTime = now.AddDate(0, 0, -6)
  1473. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1474. endTime = now
  1475. } else if queryType == "last_30day" {
  1476. beginTime = now.AddDate(0, 0, -29)
  1477. beginTime = time.Date(beginTime.Year(), beginTime.Month(), beginTime.Day(), 0, 0, 0, 0, now.Location())
  1478. endTime = now
  1479. } else if queryType == "current_month" {
  1480. endTime = now
  1481. beginTime = time.Date(endTime.Year(), endTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1482. } else if queryType == "current_year" {
  1483. endTime = now
  1484. beginTime = time.Date(endTime.Year(), 1, 1, 0, 0, 0, 0, now.Location())
  1485. } else if queryType == "last_month" {
  1486. lastMonthTime := now.AddDate(0, -1, 0)
  1487. beginTime = time.Date(lastMonthTime.Year(), lastMonthTime.Month(), 1, 0, 0, 0, 0, now.Location())
  1488. endTime = time.Date(now.Year(), now.Month(), 1, 0, 0, 0, 0, now.Location())
  1489. }
  1490. } else {
  1491. if beginTimeStr == "" || endTimeStr == "" {
  1492. //如果查询类型和开始时间结束时间都未设置,按queryType=all处理
  1493. recordCloudbrainDuration, err := models.GetDurationRecordBeginTime()
  1494. if err != nil {
  1495. log.Error("Can not get recordCloudbrain", err)
  1496. ctx.Error(http.StatusBadRequest, ctx.Tr("repo.record_begintime_get_err"))
  1497. return beginTime, endTime
  1498. }
  1499. brainRecordBeginTime := recordCloudbrainDuration[0].DateTime.AsTime()
  1500. beginTime = brainRecordBeginTime
  1501. endTime = now
  1502. } else {
  1503. beginTime, err = time.ParseInLocation("2006-01-02", beginTimeStr, time.Local)
  1504. if err != nil {
  1505. log.Error("Can not ParseInLocation.", err)
  1506. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1507. return beginTime, endTime
  1508. }
  1509. endTime, err = time.ParseInLocation("2006-01-02", endTimeStr, time.Local)
  1510. if err != nil {
  1511. log.Error("Can not ParseInLocation.", err)
  1512. ctx.Error(http.StatusBadRequest, ctx.Tr("ParseInLocation_get_error"))
  1513. return beginTime, endTime
  1514. }
  1515. if endTime.After(time.Now()) {
  1516. endTime = time.Now()
  1517. }
  1518. }
  1519. }
  1520. return beginTime, endTime
  1521. }
  1522. func getAiCenterUsageDuration(beginTime time.Time, endTime time.Time, cloudbrainStatistics []*models.CloudbrainDurationStatistic) (int, int, float64) {
  1523. totalDuration := int(0)
  1524. usageDuration := int(0)
  1525. usageRate := float64(0)
  1526. for _, cloudbrainStatistic := range cloudbrainStatistics {
  1527. if int64(cloudbrainStatistic.DateTime) >= beginTime.Unix() && int64(cloudbrainStatistic.DateTime) < endTime.Unix() {
  1528. totalDuration += cloudbrainStatistic.CardsTotalDuration
  1529. usageDuration += cloudbrainStatistic.CardsUseDuration
  1530. }
  1531. }
  1532. if totalDuration == 0 || usageDuration == 0 {
  1533. usageRate = 0
  1534. } else {
  1535. usageRate = float64(usageDuration) / float64(totalDuration)
  1536. }
  1537. return totalDuration, usageDuration, usageRate
  1538. }
  1539. func getDurationStatistic(beginTime time.Time, endTime time.Time) (models.DurationRateStatistic, models.DurationRateStatistic, float64) {
  1540. OpenITotalDuration := make(map[string]int)
  1541. OpenIUsageDuration := make(map[string]int)
  1542. OpenIUsageRate := make(map[string]float64)
  1543. C2NetTotalDuration := make(map[string]int)
  1544. C2NetUsageDuration := make(map[string]int)
  1545. OpenIDurationRate := models.DurationRateStatistic{}
  1546. C2NetDurationRate := models.DurationRateStatistic{}
  1547. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1548. BeginTime: beginTime,
  1549. EndTime: endTime,
  1550. })
  1551. if err != nil {
  1552. log.Error("GetCardDurationStatistics error:", err)
  1553. return OpenIDurationRate, C2NetDurationRate, 0
  1554. }
  1555. for _, cloudbrainStatistic := range cardDurationStatistics {
  1556. aiCenterName := cloudbrainStatistic.AiCenterCode + "/" + repo.GetAiCenterNameByCode(cloudbrainStatistic.AiCenterCode)
  1557. if cloudbrainStatistic.Cluster == models.OpenICluster {
  1558. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1559. OpenITotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1560. } else {
  1561. OpenITotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1562. }
  1563. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1564. OpenIUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1565. } else {
  1566. OpenIUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1567. }
  1568. }
  1569. if cloudbrainStatistic.Cluster == models.C2NetCluster {
  1570. if _, ok := C2NetTotalDuration[aiCenterName]; !ok {
  1571. C2NetTotalDuration[aiCenterName] = cloudbrainStatistic.CardsTotalDuration
  1572. } else {
  1573. C2NetTotalDuration[aiCenterName] += cloudbrainStatistic.CardsTotalDuration
  1574. }
  1575. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1576. C2NetUsageDuration[aiCenterName] = cloudbrainStatistic.CardsUseDuration
  1577. } else {
  1578. C2NetUsageDuration[aiCenterName] += cloudbrainStatistic.CardsUseDuration
  1579. }
  1580. }
  1581. }
  1582. ResourceAiCenterRes, err := models.GetResourceAiCenters()
  1583. if err != nil {
  1584. log.Error("Can not get ResourceAiCenterRes.", err)
  1585. return OpenIDurationRate, C2NetDurationRate, 0
  1586. }
  1587. for _, v := range ResourceAiCenterRes {
  1588. aiCenterName := v.AiCenterCode + "/" + repo.GetAiCenterNameByCode(v.AiCenterCode)
  1589. if cutString(v.AiCenterCode, 4) == cutString(models.AICenterOfCloudBrainOne, 4) {
  1590. if _, ok := OpenIUsageDuration[aiCenterName]; !ok {
  1591. OpenIUsageDuration[aiCenterName] = 0
  1592. }
  1593. if _, ok := OpenITotalDuration[aiCenterName]; !ok {
  1594. OpenITotalDuration[aiCenterName] = 0
  1595. }
  1596. } else {
  1597. if _, ok := C2NetUsageDuration[aiCenterName]; !ok {
  1598. C2NetUsageDuration[aiCenterName] = 0
  1599. }
  1600. }
  1601. }
  1602. totalCanUse := float64(0)
  1603. totalUse := float64(0)
  1604. totalUsageRate := float64(0)
  1605. for k, v := range OpenITotalDuration {
  1606. for i, j := range OpenIUsageDuration {
  1607. if k == i {
  1608. OpenIUsageRate[k] = float64(j) / float64(v)
  1609. }
  1610. }
  1611. }
  1612. for _, v := range OpenITotalDuration {
  1613. totalCanUse += float64(v)
  1614. }
  1615. for _, v := range OpenIUsageRate {
  1616. totalUse += float64(v)
  1617. }
  1618. if totalCanUse == 0 || totalUse == 0 {
  1619. totalUsageRate = 0
  1620. } else {
  1621. totalUsageRate = totalUse / totalCanUse
  1622. }
  1623. OpenIDurationRate.AiCenterTotalDurationStat = OpenITotalDuration
  1624. OpenIDurationRate.AiCenterUsageDurationStat = OpenIUsageDuration
  1625. OpenIDurationRate.UsageRate = OpenIUsageRate
  1626. C2NetDurationRate.AiCenterTotalDurationStat = C2NetTotalDuration
  1627. C2NetDurationRate.AiCenterUsageDurationStat = C2NetUsageDuration
  1628. return OpenIDurationRate, C2NetDurationRate, totalUsageRate
  1629. }
  1630. func cutString(str string, lens int) string {
  1631. if len(str) < lens {
  1632. return str
  1633. }
  1634. return str[:lens]
  1635. }
  1636. func getDayCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) ([]models.DateUsageStatistic, int, error) {
  1637. now := time.Now()
  1638. endTimeTemp := time.Date(endTime.Year(), endTime.Month(), endTime.Day(), 0, 0, 0, 0, now.Location())
  1639. if endTimeTemp.Equal(endTime) {
  1640. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1641. }
  1642. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1643. BeginTime: beginTime,
  1644. EndTime: endTime,
  1645. AiCenterCode: aiCenterCode,
  1646. })
  1647. if err != nil {
  1648. log.Error("GetCardDurationStatistics error:", err)
  1649. return nil, 0, err
  1650. }
  1651. dayCloudbrainInfo := make([]models.DateUsageStatistic, 0)
  1652. count := 0
  1653. for beginTime.Before(endTimeTemp) || beginTime.Equal(endTimeTemp) {
  1654. TotalDuration, UsageDuration, UsageRate := getAiCenterUsageDuration(endTimeTemp, endTime, cardDurationStatistics)
  1655. dayCloudbrainInfo = append(dayCloudbrainInfo, models.DateUsageStatistic{
  1656. Date: endTimeTemp.Format("2006/01/02"),
  1657. UsageDuration: UsageDuration,
  1658. TotalDuration: TotalDuration,
  1659. UsageRate: UsageRate,
  1660. })
  1661. endTime = endTimeTemp
  1662. endTimeTemp = endTimeTemp.AddDate(0, 0, -1)
  1663. if endTimeTemp.Before(beginTime) && beginTime.Before(endTime) {
  1664. endTimeTemp = beginTime
  1665. }
  1666. count += 1
  1667. }
  1668. return dayCloudbrainInfo, count, nil
  1669. }
  1670. func getHourCloudbrainDuration(beginTime time.Time, endTime time.Time, aiCenterCode string) (models.HourTimeStatistic, error) {
  1671. hourTimeTotalDuration := make(map[string]int)
  1672. hourTimeUsageDuration := make(map[string]int)
  1673. hourTimeUsageRate := make(map[string]float64)
  1674. hourTimeStatistic := models.HourTimeStatistic{}
  1675. cardDurationStatistics, err := models.GetCardDurationStatistics(&models.DurationStatisticOptions{
  1676. BeginTime: beginTime,
  1677. EndTime: endTime,
  1678. })
  1679. if err != nil {
  1680. log.Error("GetCardDurationStatistics error:", err)
  1681. return hourTimeStatistic, err
  1682. }
  1683. for _, cloudbrainStatistic := range cardDurationStatistics {
  1684. if cloudbrainStatistic.AiCenterCode == aiCenterCode {
  1685. if _, ok := hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1686. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsTotalDuration
  1687. } else {
  1688. hourTimeTotalDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsTotalDuration
  1689. }
  1690. if _, ok := hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)]; !ok {
  1691. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] = cloudbrainStatistic.CardsUseDuration
  1692. } else {
  1693. hourTimeUsageDuration[strconv.Itoa(cloudbrainStatistic.HourTime)] += cloudbrainStatistic.CardsUseDuration
  1694. }
  1695. }
  1696. }
  1697. hourTimeList := []string{"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "10", "11", "12", "13", "14", "15", "16", "17", "18", "19", "20", "21", "22", "23"}
  1698. for _, v := range hourTimeList {
  1699. if _, ok := hourTimeUsageDuration[v]; !ok {
  1700. hourTimeUsageDuration[v] = 0
  1701. }
  1702. if _, ok := hourTimeTotalDuration[v]; !ok {
  1703. hourTimeTotalDuration[v] = 0
  1704. }
  1705. }
  1706. for k, v := range hourTimeTotalDuration {
  1707. for i, j := range hourTimeUsageDuration {
  1708. if k == i {
  1709. if v == 0 || j == 0 {
  1710. hourTimeUsageRate[k] = 0
  1711. } else {
  1712. hourTimeUsageRate[k] = float64(j) / float64(v)
  1713. }
  1714. }
  1715. }
  1716. }
  1717. hourTimeStatistic.HourTimeTotalDuration = hourTimeTotalDuration
  1718. hourTimeStatistic.HourTimeUsageDuration = hourTimeUsageDuration
  1719. hourTimeStatistic.HourTimeUsageRate = hourTimeUsageRate
  1720. return hourTimeStatistic, nil
  1721. }
  1722. func CloudbrainUpdateAiCenter(ctx *context.Context) {
  1723. repo.CloudbrainDurationStatisticHour()
  1724. ctx.JSON(http.StatusOK, map[string]interface{}{
  1725. "message": 0,
  1726. })
  1727. }
  1728. func GetResourceQueues(ctx *context.Context) {
  1729. resourceQueues, err := models.GetCanUseCardInfo()
  1730. if err != nil {
  1731. log.Info("GetCanUseCardInfo err: %v", err)
  1732. return
  1733. }
  1734. Resource := make([]*models.ResourceQueue, 0)
  1735. aiCenterCodeMap := make(map[string]string)
  1736. for _, resourceQueue := range resourceQueues {
  1737. if _, ok := aiCenterCodeMap[resourceQueue.AiCenterCode]; !ok {
  1738. resourceQueue.AiCenterName = repo.GetAiCenterNameByCode(resourceQueue.AiCenterCode)
  1739. aiCenterCodeMap[resourceQueue.AiCenterCode] = resourceQueue.AiCenterCode
  1740. Resource = append(Resource, resourceQueue)
  1741. }
  1742. }
  1743. ctx.JSON(http.StatusOK, map[string]interface{}{
  1744. "resourceQueues": Resource,
  1745. })
  1746. }