- /*
-
- Copyright (c) [2023] [pcm]
- [pcm-coordinator] is licensed under Mulan PSL v2.
- You can use this software according to the terms and conditions of the Mulan PSL v2.
- You may obtain a copy of Mulan PSL v2 at:
- http://license.coscl.org.cn/MulanPSL2
- THIS SOFTWARE IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
- EITHER EXPaRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
- MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
- See the Mulan PSL v2 for more details.
-
- */
-
- package mqs
-
- import (
- "context"
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/scheduler"
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/scheduler/schedulers"
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/scheduler/service"
- "gitlink.org.cn/jcce-pcm/pcm-coordinator/api/internal/svc"
- )
-
- /*
- *
- Listening to the payment flow status change notification message queue
- */
- type AiQueue struct {
- ctx context.Context
- svcCtx *svc.ServiceContext
- scheduler *scheduler.Scheduler
- }
-
- func NewAiMq(ctx context.Context, svcCtx *svc.ServiceContext) *AiQueue {
- aiExecutorMap, aiCollectorMap := service.InitAiClusterMap(ctx, svcCtx)
- return &AiQueue{
- ctx: ctx,
- svcCtx: svcCtx,
- scheduler: scheduler.NewScheduler2(aiCollectorMap, nil, aiExecutorMap),
- }
- }
-
- func (l *AiQueue) Consume(val string) error {
- // 接受消息, 根据标签筛选过滤
- aiSchdl, _ := schedulers.NewAiScheduler(val, l.scheduler)
-
- // 调度算法
- err := l.scheduler.AssignAndSchedule(aiSchdl)
- if err != nil {
- return err
- }
-
- return nil
- }
|