mirror of https://github.com/milvus-io/milvus.git
fix: Fix large growing segment (#37388)
Consider the `sealProportion` factor during segment allocation. issue: https://github.com/milvus-io/milvus/issues/37387 Signed-off-by: bigsheeper <yihao.dai@zilliz.com>pull/37506/head
parent
994f52fab8
commit
36bb87d9b6
|
@ -108,7 +108,18 @@ func AllocatePolicyL1(segments []*SegmentInfo, count int64,
|
|||
for _, allocation := range segment.allocations {
|
||||
allocSize += allocation.NumOfRows
|
||||
}
|
||||
free := segment.GetMaxRowNum() - segment.GetNumOfRows() - allocSize
|
||||
|
||||
// When inserts are too fast, hardTimeTick may lag, causing segment to be unable to seal in time.
|
||||
// To prevent allocating large segment, introducing the sealProportion factor here.
|
||||
// The condition `free < 0` ensures that the allocation exceeds the minimum sealable size,
|
||||
// preventing segments from remaining unsealable indefinitely.
|
||||
maxRowsWithSealProportion := int64(float64(segment.GetMaxRowNum()) * paramtable.Get().DataCoordCfg.SegmentSealProportion.GetAsFloat())
|
||||
free := maxRowsWithSealProportion - segment.GetNumOfRows() - allocSize
|
||||
if free < 0 {
|
||||
continue
|
||||
}
|
||||
|
||||
free = segment.GetMaxRowNum() - segment.GetNumOfRows() - allocSize
|
||||
if free < count {
|
||||
continue
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue