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