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.

getcenterqueueinglogic.go 1.7 kB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970
  1. package ai
  2. import (
  3. "context"
  4. "sort"
  5. "gitlink.org.cn/JointCloud/pcm-coordinator/api/internal/svc"
  6. "gitlink.org.cn/JointCloud/pcm-coordinator/api/internal/types"
  7. "github.com/zeromicro/go-zero/core/logx"
  8. )
  9. type GetCenterQueueingLogic struct {
  10. logx.Logger
  11. ctx context.Context
  12. svcCtx *svc.ServiceContext
  13. }
  14. func NewGetCenterQueueingLogic(ctx context.Context, svcCtx *svc.ServiceContext) *GetCenterQueueingLogic {
  15. return &GetCenterQueueingLogic{
  16. Logger: logx.WithContext(ctx),
  17. ctx: ctx,
  18. svcCtx: svcCtx,
  19. }
  20. }
  21. func (l *GetCenterQueueingLogic) GetCenterQueueing() (resp *types.CenterQueueingResp, err error) {
  22. resp = &types.CenterQueueingResp{}
  23. adapters, err := l.svcCtx.Scheduler.AiStorages.GetAdaptersByType("1")
  24. if err != nil {
  25. return nil, err
  26. }
  27. for _, adapter := range adapters {
  28. clusters, err := l.svcCtx.Scheduler.AiStorages.GetClustersByAdapterId(adapter.Id)
  29. if err != nil {
  30. continue
  31. }
  32. for _, cluster := range clusters.List {
  33. queues, err := l.svcCtx.Scheduler.AiStorages.GetClusterTaskQueues(adapter.Id, cluster.Id)
  34. if err != nil {
  35. continue
  36. }
  37. //todo sync current task queues
  38. current := &types.CenterQueue{
  39. Name: cluster.Name,
  40. QueueingNum: int32(queues[0].QueueNum),
  41. }
  42. history := &types.CenterQueue{
  43. Name: cluster.Name,
  44. QueueingNum: int32(queues[0].QueueNum),
  45. }
  46. resp.Current = append(resp.Current, current)
  47. resp.History = append(resp.History, history)
  48. }
  49. }
  50. sortQueueingNum(resp.Current)
  51. sortQueueingNum(resp.History)
  52. return resp, nil
  53. }
  54. func sortQueueingNum(q []*types.CenterQueue) {
  55. sort.Slice(q, func(i, j int) bool {
  56. return q[i].QueueingNum > q[j].QueueingNum
  57. })
  58. }

PCM is positioned as Software stack over Cloud, aiming to build the standards and ecology of heterogeneous cloud collaboration for JCC in a non intrusive and autonomous peer-to-peer manner.