mirror of https://github.com/milvus-io/milvus.git
fix: Separate L0 and Mix trigger interval (#37190)
See also: #37108 - Add MixCompactionTriggerInterval, default 60s - Add L0CompactionTriggerInterval, default 10s - Export Single related compaction configs - Raise SingleCompactionDeltaLogMaxSize from 2MB to 16MB --------- Signed-off-by: yangxuan <xuan.yang@zilliz.com>pull/37561/head
parent
2a4c00de9d
commit
a45a288a25
|
@ -564,6 +564,23 @@ dataCoord:
|
||||||
maxParallelTaskNum: 10
|
maxParallelTaskNum: 10
|
||||||
dropTolerance: 86400 # Compaction task will be cleaned after finish longer than this time(in seconds)
|
dropTolerance: 86400 # Compaction task will be cleaned after finish longer than this time(in seconds)
|
||||||
gcInterval: 1800 # The time interval in seconds for compaction gc
|
gcInterval: 1800 # The time interval in seconds for compaction gc
|
||||||
|
mix:
|
||||||
|
triggerInterval: 60 # The time interval in seconds to trigger mix compaction
|
||||||
|
levelzero:
|
||||||
|
triggerInterval: 10 # The time interval in seconds for trigger L0 compaction
|
||||||
|
forceTrigger:
|
||||||
|
minSize: 8388608 # The minmum size in bytes to force trigger a LevelZero Compaction, default as 8MB
|
||||||
|
maxSize: 67108864 # The maxmum size in bytes to force trigger a LevelZero Compaction, default as 64MB
|
||||||
|
deltalogMinNum: 10 # The minimum number of deltalog files to force trigger a LevelZero Compaction
|
||||||
|
deltalogMaxNum: 30 # The maxmum number of deltalog files to force trigger a LevelZero Compaction, default as 30
|
||||||
|
single:
|
||||||
|
ratio:
|
||||||
|
threshold: 0.2 # The ratio threshold of a segment to trigger a single compaction, default as 0.2
|
||||||
|
deltalog:
|
||||||
|
maxsize: 16777216 # The deltalog size of a segment to trigger a single compaction, default as 16MB
|
||||||
|
maxnum: 200 # The deltalog count of a segment to trigger a compaction, default as 200
|
||||||
|
expiredlog:
|
||||||
|
maxsize: 10485760 # The expired log size of a segment to trigger a compaction, default as 10MB
|
||||||
clustering:
|
clustering:
|
||||||
enable: true # Enable clustering compaction
|
enable: true # Enable clustering compaction
|
||||||
autoEnable: false # Enable auto clustering compaction
|
autoEnable: false # Enable auto clustering compaction
|
||||||
|
@ -579,12 +596,6 @@ dataCoord:
|
||||||
minClusterSizeRatio: 0.01 # minimum cluster size / avg size in Kmeans train
|
minClusterSizeRatio: 0.01 # minimum cluster size / avg size in Kmeans train
|
||||||
maxClusterSizeRatio: 10 # maximum cluster size / avg size in Kmeans train
|
maxClusterSizeRatio: 10 # maximum cluster size / avg size in Kmeans train
|
||||||
maxClusterSize: 5g # maximum cluster size in Kmeans train
|
maxClusterSize: 5g # maximum cluster size in Kmeans train
|
||||||
levelzero:
|
|
||||||
forceTrigger:
|
|
||||||
minSize: 8388608 # The minmum size in bytes to force trigger a LevelZero Compaction, default as 8MB
|
|
||||||
maxSize: 67108864 # The maxmum size in bytes to force trigger a LevelZero Compaction, default as 64MB
|
|
||||||
deltalogMinNum: 10 # The minimum number of deltalog files to force trigger a LevelZero Compaction
|
|
||||||
deltalogMaxNum: 30 # The maxmum number of deltalog files to force trigger a LevelZero Compaction, default as 30
|
|
||||||
syncSegmentsInterval: 300 # The time interval for regularly syncing segments
|
syncSegmentsInterval: 300 # The time interval for regularly syncing segments
|
||||||
enableGarbageCollection: true # Switch value to control if to enable garbage collection to clear the discarded data in MinIO or S3 service.
|
enableGarbageCollection: true # Switch value to control if to enable garbage collection to clear the discarded data in MinIO or S3 service.
|
||||||
gc:
|
gc:
|
||||||
|
@ -1077,4 +1088,4 @@ knowhere:
|
||||||
pq_code_budget_gb_ratio: 0.125 # Size limit on the PQ code (compared with raw data)
|
pq_code_budget_gb_ratio: 0.125 # Size limit on the PQ code (compared with raw data)
|
||||||
search_cache_budget_gb_ratio: 0.1 # Ratio of cached node numbers to raw data
|
search_cache_budget_gb_ratio: 0.1 # Ratio of cached node numbers to raw data
|
||||||
search: # Diskann search params
|
search: # Diskann search params
|
||||||
beam_width_ratio: 4.0 # Ratio between the maximum number of IO requests per search iteration and CPU number.
|
beam_width_ratio: 4.0 # Ratio between the maximum number of IO requests per search iteration and CPU number
|
||||||
|
|
|
@ -109,7 +109,7 @@ func newCompactionTrigger(
|
||||||
}
|
}
|
||||||
|
|
||||||
func (t *compactionTrigger) start() {
|
func (t *compactionTrigger) start() {
|
||||||
t.globalTrigger = time.NewTicker(Params.DataCoordCfg.GlobalCompactionInterval.GetAsDuration(time.Second))
|
t.globalTrigger = time.NewTicker(Params.DataCoordCfg.MixCompactionTriggerInterval.GetAsDuration(time.Second))
|
||||||
t.closeWaiter.Add(2)
|
t.closeWaiter.Add(2)
|
||||||
go func() {
|
go func() {
|
||||||
defer logutil.LogPanic()
|
defer logutil.LogPanic()
|
||||||
|
@ -132,8 +132,6 @@ func (t *compactionTrigger) start() {
|
||||||
default:
|
default:
|
||||||
// no need to handle err in handleSignal
|
// no need to handle err in handleSignal
|
||||||
t.handleSignal(signal)
|
t.handleSignal(signal)
|
||||||
// shouldn't reset, otherwise a frequent flushed collection will affect other collections
|
|
||||||
// t.globalTrigger.Reset(Params.DataCoordCfg.GlobalCompactionInterval)
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -108,11 +108,11 @@ func (m *CompactionTriggerManager) startLoop() {
|
||||||
defer logutil.LogPanic()
|
defer logutil.LogPanic()
|
||||||
defer m.closeWg.Done()
|
defer m.closeWg.Done()
|
||||||
|
|
||||||
l0Ticker := time.NewTicker(Params.DataCoordCfg.GlobalCompactionInterval.GetAsDuration(time.Second))
|
l0Ticker := time.NewTicker(Params.DataCoordCfg.L0CompactionTriggerInterval.GetAsDuration(time.Second))
|
||||||
defer l0Ticker.Stop()
|
defer l0Ticker.Stop()
|
||||||
clusteringTicker := time.NewTicker(Params.DataCoordCfg.ClusteringCompactionTriggerInterval.GetAsDuration(time.Second))
|
clusteringTicker := time.NewTicker(Params.DataCoordCfg.ClusteringCompactionTriggerInterval.GetAsDuration(time.Second))
|
||||||
defer clusteringTicker.Stop()
|
defer clusteringTicker.Stop()
|
||||||
singleTicker := time.NewTicker(Params.DataCoordCfg.GlobalCompactionInterval.GetAsDuration(time.Second))
|
singleTicker := time.NewTicker(Params.DataCoordCfg.MixCompactionTriggerInterval.GetAsDuration(time.Second))
|
||||||
defer singleTicker.Stop()
|
defer singleTicker.Stop()
|
||||||
log.Info("Compaction trigger manager start")
|
log.Info("Compaction trigger manager start")
|
||||||
for {
|
for {
|
||||||
|
|
|
@ -3214,11 +3214,15 @@ type dataCoordConfig struct {
|
||||||
CompactionDropToleranceInSeconds ParamItem `refreshable:"true"`
|
CompactionDropToleranceInSeconds ParamItem `refreshable:"true"`
|
||||||
CompactionGCIntervalInSeconds ParamItem `refreshable:"true"`
|
CompactionGCIntervalInSeconds ParamItem `refreshable:"true"`
|
||||||
CompactionCheckIntervalInSeconds ParamItem `refreshable:"false"`
|
CompactionCheckIntervalInSeconds ParamItem `refreshable:"false"`
|
||||||
|
MixCompactionTriggerInterval ParamItem `refreshable:"false"`
|
||||||
|
L0CompactionTriggerInterval ParamItem `refreshable:"false"`
|
||||||
|
GlobalCompactionInterval ParamItem `refreshable:"false"`
|
||||||
|
|
||||||
SingleCompactionRatioThreshold ParamItem `refreshable:"true"`
|
SingleCompactionRatioThreshold ParamItem `refreshable:"true"`
|
||||||
SingleCompactionDeltaLogMaxSize ParamItem `refreshable:"true"`
|
SingleCompactionDeltaLogMaxSize ParamItem `refreshable:"true"`
|
||||||
SingleCompactionExpiredLogMaxSize ParamItem `refreshable:"true"`
|
SingleCompactionExpiredLogMaxSize ParamItem `refreshable:"true"`
|
||||||
SingleCompactionDeltalogMaxNum ParamItem `refreshable:"true"`
|
SingleCompactionDeltalogMaxNum ParamItem `refreshable:"true"`
|
||||||
GlobalCompactionInterval ParamItem `refreshable:"false"`
|
|
||||||
ChannelCheckpointMaxLag ParamItem `refreshable:"true"`
|
ChannelCheckpointMaxLag ParamItem `refreshable:"true"`
|
||||||
SyncSegmentsInterval ParamItem `refreshable:"false"`
|
SyncSegmentsInterval ParamItem `refreshable:"false"`
|
||||||
|
|
||||||
|
@ -3592,13 +3596,17 @@ During compaction, the size of segment # of rows is able to exceed segment max #
|
||||||
Key: "dataCoord.compaction.single.ratio.threshold",
|
Key: "dataCoord.compaction.single.ratio.threshold",
|
||||||
Version: "2.0.0",
|
Version: "2.0.0",
|
||||||
DefaultValue: "0.2",
|
DefaultValue: "0.2",
|
||||||
|
Doc: "The ratio threshold of a segment to trigger a single compaction, default as 0.2",
|
||||||
|
Export: true,
|
||||||
}
|
}
|
||||||
p.SingleCompactionRatioThreshold.Init(base.mgr)
|
p.SingleCompactionRatioThreshold.Init(base.mgr)
|
||||||
|
|
||||||
p.SingleCompactionDeltaLogMaxSize = ParamItem{
|
p.SingleCompactionDeltaLogMaxSize = ParamItem{
|
||||||
Key: "dataCoord.compaction.single.deltalog.maxsize",
|
Key: "dataCoord.compaction.single.deltalog.maxsize",
|
||||||
Version: "2.0.0",
|
Version: "2.0.0",
|
||||||
DefaultValue: strconv.Itoa(2 * 1024 * 1024),
|
DefaultValue: "16777216",
|
||||||
|
Doc: "The deltalog size of a segment to trigger a single compaction, default as 16MB",
|
||||||
|
Export: true,
|
||||||
}
|
}
|
||||||
p.SingleCompactionDeltaLogMaxSize.Init(base.mgr)
|
p.SingleCompactionDeltaLogMaxSize.Init(base.mgr)
|
||||||
|
|
||||||
|
@ -3606,6 +3614,8 @@ During compaction, the size of segment # of rows is able to exceed segment max #
|
||||||
Key: "dataCoord.compaction.single.expiredlog.maxsize",
|
Key: "dataCoord.compaction.single.expiredlog.maxsize",
|
||||||
Version: "2.0.0",
|
Version: "2.0.0",
|
||||||
DefaultValue: "10485760",
|
DefaultValue: "10485760",
|
||||||
|
Doc: "The expired log size of a segment to trigger a compaction, default as 10MB",
|
||||||
|
Export: true,
|
||||||
}
|
}
|
||||||
p.SingleCompactionExpiredLogMaxSize.Init(base.mgr)
|
p.SingleCompactionExpiredLogMaxSize.Init(base.mgr)
|
||||||
|
|
||||||
|
@ -3613,6 +3623,8 @@ During compaction, the size of segment # of rows is able to exceed segment max #
|
||||||
Key: "dataCoord.compaction.single.deltalog.maxnum",
|
Key: "dataCoord.compaction.single.deltalog.maxnum",
|
||||||
Version: "2.0.0",
|
Version: "2.0.0",
|
||||||
DefaultValue: "200",
|
DefaultValue: "200",
|
||||||
|
Doc: "The deltalog count of a segment to trigger a compaction, default as 200",
|
||||||
|
Export: true,
|
||||||
}
|
}
|
||||||
p.SingleCompactionDeltalogMaxNum.Init(base.mgr)
|
p.SingleCompactionDeltalogMaxNum.Init(base.mgr)
|
||||||
|
|
||||||
|
@ -3620,9 +3632,28 @@ During compaction, the size of segment # of rows is able to exceed segment max #
|
||||||
Key: "dataCoord.compaction.global.interval",
|
Key: "dataCoord.compaction.global.interval",
|
||||||
Version: "2.0.0",
|
Version: "2.0.0",
|
||||||
DefaultValue: "60",
|
DefaultValue: "60",
|
||||||
|
Doc: "deprecated",
|
||||||
}
|
}
|
||||||
p.GlobalCompactionInterval.Init(base.mgr)
|
p.GlobalCompactionInterval.Init(base.mgr)
|
||||||
|
|
||||||
|
p.MixCompactionTriggerInterval = ParamItem{
|
||||||
|
Key: "dataCoord.compaction.mix.triggerInterval",
|
||||||
|
Version: "2.4.15",
|
||||||
|
Doc: "The time interval in seconds to trigger mix compaction",
|
||||||
|
DefaultValue: "60",
|
||||||
|
Export: true,
|
||||||
|
}
|
||||||
|
p.MixCompactionTriggerInterval.Init(base.mgr)
|
||||||
|
|
||||||
|
p.L0CompactionTriggerInterval = ParamItem{
|
||||||
|
Key: "dataCoord.compaction.levelzero.triggerInterval",
|
||||||
|
Version: "2.4.15",
|
||||||
|
Doc: "The time interval in seconds for trigger L0 compaction",
|
||||||
|
DefaultValue: "10",
|
||||||
|
Export: true,
|
||||||
|
}
|
||||||
|
p.L0CompactionTriggerInterval.Init(base.mgr)
|
||||||
|
|
||||||
p.ChannelCheckpointMaxLag = ParamItem{
|
p.ChannelCheckpointMaxLag = ParamItem{
|
||||||
Key: "dataCoord.compaction.channelMaxCPLag",
|
Key: "dataCoord.compaction.channelMaxCPLag",
|
||||||
Version: "2.4.0",
|
Version: "2.4.0",
|
||||||
|
|
|
@ -33,13 +33,15 @@ func (s *CompactionSuite) SetupSuite() {
|
||||||
s.MiniClusterSuite.SetupSuite()
|
s.MiniClusterSuite.SetupSuite()
|
||||||
|
|
||||||
paramtable.Init()
|
paramtable.Init()
|
||||||
paramtable.Get().Save(paramtable.Get().DataCoordCfg.GlobalCompactionInterval.Key, "1")
|
paramtable.Get().Save(paramtable.Get().DataCoordCfg.MixCompactionTriggerInterval.Key, "1")
|
||||||
|
paramtable.Get().Save(paramtable.Get().DataCoordCfg.L0CompactionTriggerInterval.Key, "1")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (s *CompactionSuite) TearDownSuite() {
|
func (s *CompactionSuite) TearDownSuite() {
|
||||||
s.MiniClusterSuite.TearDownSuite()
|
s.MiniClusterSuite.TearDownSuite()
|
||||||
|
|
||||||
paramtable.Get().Reset(paramtable.Get().DataCoordCfg.GlobalCompactionInterval.Key)
|
paramtable.Get().Reset(paramtable.Get().DataCoordCfg.L0CompactionTriggerInterval.Key)
|
||||||
|
paramtable.Get().Reset(paramtable.Get().DataCoordCfg.MixCompactionTriggerInterval.Key)
|
||||||
}
|
}
|
||||||
|
|
||||||
func TestCompaction(t *testing.T) {
|
func TestCompaction(t *testing.T) {
|
||||||
|
|
|
@ -273,9 +273,9 @@ func (s *L2SingleCompactionSuite) TestL2SingleCompaction() {
|
||||||
func TestL2SingleCompaction(t *testing.T) {
|
func TestL2SingleCompaction(t *testing.T) {
|
||||||
paramtable.Init()
|
paramtable.Init()
|
||||||
// to speed up the test
|
// to speed up the test
|
||||||
paramtable.Get().Save(paramtable.Get().DataCoordCfg.GlobalCompactionInterval.Key, "10")
|
paramtable.Get().Save(paramtable.Get().DataCoordCfg.MixCompactionTriggerInterval.Key, "10")
|
||||||
paramtable.Get().Save(paramtable.Get().DataCoordCfg.LevelZeroCompactionTriggerDeltalogMinNum.Key, "0")
|
paramtable.Get().Save(paramtable.Get().DataCoordCfg.LevelZeroCompactionTriggerDeltalogMinNum.Key, "0")
|
||||||
defer paramtable.Get().Reset(paramtable.Get().DataCoordCfg.GlobalCompactionInterval.Key)
|
defer paramtable.Get().Reset(paramtable.Get().DataCoordCfg.MixCompactionTriggerInterval.Key)
|
||||||
defer paramtable.Get().Reset(paramtable.Get().DataCoordCfg.LevelZeroCompactionTriggerDeltalogMinNum.Key)
|
defer paramtable.Get().Reset(paramtable.Get().DataCoordCfg.LevelZeroCompactionTriggerDeltalogMinNum.Key)
|
||||||
|
|
||||||
suite.Run(t, new(L2SingleCompactionSuite))
|
suite.Run(t, new(L2SingleCompactionSuite))
|
||||||
|
|
Loading…
Reference in New Issue