Files
EdgeCommon/pkg/serverconfigs/schedulingconfigs/scheduling.go
2021-09-20 11:54:21 +08:00

40 lines
880 B
Go

package schedulingconfigs
import (
"github.com/TeaOSLab/EdgeCommon/pkg/serverconfigs/shared"
"github.com/iwind/TeaGo/maps"
)
// SchedulingInterface 调度算法接口
type SchedulingInterface interface {
// HasCandidates 是否有候选对象
HasCandidates() bool
// Add 添加候选对象
Add(candidate ...CandidateInterface)
// Start 启动
Start()
// Next 查找下一个候选对象
Next(call *shared.RequestCall) CandidateInterface
// Summary 获取简要信息
Summary() maps.Map
}
// Scheduling 调度算法基础类
type Scheduling struct {
Candidates []CandidateInterface
}
// HasCandidates 判断是否有候选对象
func (this *Scheduling) HasCandidates() bool {
return len(this.Candidates) > 0
}
// Add 添加候选对象
func (this *Scheduling) Add(candidate ...CandidateInterface) {
this.Candidates = append(this.Candidates, candidate...)
}