You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

cloudbrain_dashboard.go 72 kB

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