mirror of https://github.com/milvus-io/milvus.git
Move task merge cap to config file (#19387)
Signed-off-by: sunby <bingyi.sun@zilliz.com> Signed-off-by: sunby <bingyi.sun@zilliz.com> Co-authored-by: sunby <bingyi.sun@zilliz.com>pull/19428/head
parent
9e18645363
commit
29d2c0bd7b
|
@ -185,6 +185,7 @@ queryCoord:
|
|||
distPullInterval: 500
|
||||
loadTimeoutSeconds: 600
|
||||
checkHandoffInterval: 5000
|
||||
taskMergeCap: 2
|
||||
|
||||
|
||||
|
||||
|
|
|
@ -6,15 +6,13 @@ import (
|
|||
"time"
|
||||
|
||||
"github.com/milvus-io/milvus/internal/log"
|
||||
. "github.com/milvus-io/milvus/internal/querycoordv2/params"
|
||||
"github.com/milvus-io/milvus/internal/util/typeutil"
|
||||
"go.uber.org/zap"
|
||||
)
|
||||
|
||||
// Merger merges tasks with the same mergeID.
|
||||
const (
|
||||
taskQueueCap = 16
|
||||
waitQueueCap = 128
|
||||
)
|
||||
const waitQueueCap = 128
|
||||
|
||||
type Merger[K comparable, R any] struct {
|
||||
stopCh chan struct{}
|
||||
|
@ -32,7 +30,7 @@ func NewMerger[K comparable, R any]() *Merger[K, R] {
|
|||
processors: typeutil.NewConcurrentSet[K](),
|
||||
queues: make(map[K]chan MergeableTask[K, R]),
|
||||
waitQueue: make(chan MergeableTask[K, R], waitQueueCap),
|
||||
outCh: make(chan MergeableTask[K, R], taskQueueCap),
|
||||
outCh: make(chan MergeableTask[K, R], Params.QueryCoordCfg.TaskMergeCap),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -68,7 +66,7 @@ func (merger *Merger[K, R]) schedule(ctx context.Context) {
|
|||
case task := <-merger.waitQueue:
|
||||
queue, ok := merger.queues[task.ID()]
|
||||
if !ok {
|
||||
queue = make(chan MergeableTask[K, R], taskQueueCap)
|
||||
queue = make(chan MergeableTask[K, R], Params.QueryCoordCfg.TaskMergeCap)
|
||||
merger.queues[task.ID()] = queue
|
||||
}
|
||||
outer:
|
||||
|
|
|
@ -7,6 +7,7 @@ import (
|
|||
|
||||
"github.com/milvus-io/milvus/internal/proto/internalpb"
|
||||
"github.com/milvus-io/milvus/internal/proto/querypb"
|
||||
. "github.com/milvus-io/milvus/internal/querycoordv2/params"
|
||||
"github.com/stretchr/testify/suite"
|
||||
)
|
||||
|
||||
|
@ -22,6 +23,8 @@ type MergerSuite struct {
|
|||
}
|
||||
|
||||
func (suite *MergerSuite) SetupSuite() {
|
||||
Params.Init()
|
||||
Params.QueryCoordCfg.TaskMergeCap = 3
|
||||
suite.collectionID = 1000
|
||||
suite.replicaID = 100
|
||||
suite.nodeID = 1
|
||||
|
|
|
@ -617,6 +617,7 @@ type queryCoordConfig struct {
|
|||
//---- Task ---
|
||||
RetryNum int32
|
||||
RetryInterval int64
|
||||
TaskMergeCap int32
|
||||
|
||||
//---- Handoff ---
|
||||
AutoHandoff bool
|
||||
|
@ -641,6 +642,7 @@ func (p *queryCoordConfig) init(base *BaseTable) {
|
|||
//---- Task ---
|
||||
p.initTaskRetryNum()
|
||||
p.initTaskRetryInterval()
|
||||
p.initTaskMergeCap()
|
||||
|
||||
//---- Handoff ---
|
||||
p.initAutoHandoff()
|
||||
|
@ -666,6 +668,10 @@ func (p *queryCoordConfig) initTaskRetryInterval() {
|
|||
p.RetryInterval = p.Base.ParseInt64WithDefault("queryCoord.task.retryinterval", int64(10*time.Second))
|
||||
}
|
||||
|
||||
func (p *queryCoordConfig) initTaskMergeCap() {
|
||||
p.TaskMergeCap = p.Base.ParseInt32WithDefault("queryCoord.taskMergeCap", 2)
|
||||
}
|
||||
|
||||
func (p *queryCoordConfig) initAutoHandoff() {
|
||||
handoff, err := p.Base.Load("queryCoord.autoHandoff")
|
||||
if err != nil {
|
||||
|
|
Loading…
Reference in New Issue