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