mirror of https://github.com/milvus-io/milvus.git
Fix load the same segments multiple times for manual LoadBalance (#16921)
Signed-off-by: yah01 <yang.cen@zilliz.com>pull/17034/head
parent
5f1d7c5267
commit
e38c6f6c44
|
@ -2068,9 +2068,7 @@ func (lbt *loadBalanceTask) execute(ctx context.Context) error {
|
||||||
log.Info("loadBalanceTask: add a childTask", zap.Int32("task type", int32(internalTask.msgType())), zap.Any("task", internalTask))
|
log.Info("loadBalanceTask: add a childTask", zap.Int32("task type", int32(internalTask.msgType())), zap.Any("task", internalTask))
|
||||||
}
|
}
|
||||||
log.Info("loadBalanceTask: assign child task done", zap.Int64s("sourceNodeIDs", lbt.SourceNodeIDs))
|
log.Info("loadBalanceTask: assign child task done", zap.Int64s("sourceNodeIDs", lbt.SourceNodeIDs))
|
||||||
}
|
} else if lbt.triggerCondition == querypb.TriggerCondition_LoadBalance {
|
||||||
|
|
||||||
if lbt.triggerCondition == querypb.TriggerCondition_LoadBalance {
|
|
||||||
if err := lbt.checkForManualLoadBalance(); err != nil {
|
if err := lbt.checkForManualLoadBalance(); err != nil {
|
||||||
lbt.setResultInfo(err)
|
lbt.setResultInfo(err)
|
||||||
return err
|
return err
|
||||||
|
@ -2084,7 +2082,6 @@ func (lbt *loadBalanceTask) execute(ctx context.Context) error {
|
||||||
|
|
||||||
balancedSegmentInfos := make(map[UniqueID]*querypb.SegmentInfo)
|
balancedSegmentInfos := make(map[UniqueID]*querypb.SegmentInfo)
|
||||||
balancedSegmentIDs := make([]UniqueID, 0)
|
balancedSegmentIDs := make([]UniqueID, 0)
|
||||||
|
|
||||||
for _, nodeID := range lbt.SourceNodeIDs {
|
for _, nodeID := range lbt.SourceNodeIDs {
|
||||||
nodeExist := lbt.cluster.hasNode(nodeID)
|
nodeExist := lbt.cluster.hasNode(nodeID)
|
||||||
if !nodeExist {
|
if !nodeExist {
|
||||||
|
@ -2159,20 +2156,18 @@ func (lbt *loadBalanceTask) execute(ctx context.Context) error {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, replica := range segmentInfo.ReplicaIds {
|
segmentBingLog := segmentID2Binlog[segmentID]
|
||||||
segmentBingLog := segmentID2Binlog[segmentID]
|
segmentLoadInfo := lbt.broker.generateSegmentLoadInfo(ctx, collectionID, partitionID, segmentBingLog, true, collectionInfo.Schema)
|
||||||
segmentLoadInfo := lbt.broker.generateSegmentLoadInfo(ctx, collectionID, partitionID, segmentBingLog, true, collectionInfo.Schema)
|
msgBase := proto.Clone(lbt.Base).(*commonpb.MsgBase)
|
||||||
msgBase := proto.Clone(lbt.Base).(*commonpb.MsgBase)
|
msgBase.MsgType = commonpb.MsgType_LoadSegments
|
||||||
msgBase.MsgType = commonpb.MsgType_LoadSegments
|
loadSegmentReq := &querypb.LoadSegmentsRequest{
|
||||||
loadSegmentReq := &querypb.LoadSegmentsRequest{
|
Base: msgBase,
|
||||||
Base: msgBase,
|
Infos: []*querypb.SegmentLoadInfo{segmentLoadInfo},
|
||||||
Infos: []*querypb.SegmentLoadInfo{segmentLoadInfo},
|
Schema: collectionInfo.Schema,
|
||||||
Schema: collectionInfo.Schema,
|
CollectionID: collectionID,
|
||||||
CollectionID: collectionID,
|
ReplicaID: lbt.replicaID,
|
||||||
ReplicaID: replica,
|
|
||||||
}
|
|
||||||
loadSegmentReqs = append(loadSegmentReqs, loadSegmentReq)
|
|
||||||
}
|
}
|
||||||
|
loadSegmentReqs = append(loadSegmentReqs, loadSegmentReq)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, info := range dmChannelInfos {
|
for _, info := range dmChannelInfos {
|
||||||
|
|
Loading…
Reference in New Issue