From 4f9b1702cf9c32d4c8558cb043eebc7db4208423 Mon Sep 17 00:00:00 2001 From: bigsheeper Date: Tue, 26 Nov 2024 15:12:07 +0800 Subject: [PATCH 1/2] enhance: Skip creating partition rate limiters when not enable Signed-off-by: bigsheeper --- internal/rootcoord/quota_center.go | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/internal/rootcoord/quota_center.go b/internal/rootcoord/quota_center.go index 98e42f5e24676..511f465c65edb 100644 --- a/internal/rootcoord/quota_center.go +++ b/internal/rootcoord/quota_center.go @@ -1182,6 +1182,15 @@ func (q *QuotaCenter) calculateRates() error { func (q *QuotaCenter) resetAllCurrentRates() error { clusterLimiter := newParamLimiterFunc(internalpb.RateScope_Cluster, allOps)() q.rateLimiter = rlinternal.NewRateLimiterTree(clusterLimiter) + + enablePartitionRateLimit := false + for rt := range getRateTypes(internalpb.RateScope_Partition, allOps) { + r := quota.GetQuotaValue(internalpb.RateScope_Partition, rt, Params) + if Limit(r) != Inf { + enablePartitionRateLimit = true + } + } + initLimiters := func(sourceCollections map[int64]map[int64][]int64) { for dbID, collections := range sourceCollections { for collectionID, partitionIDs := range collections { @@ -1192,21 +1201,20 @@ func (q *QuotaCenter) resetAllCurrentRates() error { } return limitVal } + q.rateLimiter.GetOrCreateDatabaseLimiters(dbID, newParamLimiterFunc(internalpb.RateScope_Database, allOps)) + q.rateLimiter.GetOrCreateCollectionLimiters(dbID, collectionID, + newParamLimiterFunc(internalpb.RateScope_Database, allOps), + newParamLimiterFuncWithLimitFunc(internalpb.RateScope_Collection, allOps, getCollectionLimitVal)) + if !enablePartitionRateLimit { + continue + } for _, partitionID := range partitionIDs { q.rateLimiter.GetOrCreatePartitionLimiters(dbID, collectionID, partitionID, newParamLimiterFunc(internalpb.RateScope_Database, allOps), newParamLimiterFuncWithLimitFunc(internalpb.RateScope_Collection, allOps, getCollectionLimitVal), newParamLimiterFunc(internalpb.RateScope_Partition, allOps)) } - if len(partitionIDs) == 0 { - q.rateLimiter.GetOrCreateCollectionLimiters(dbID, collectionID, - newParamLimiterFunc(internalpb.RateScope_Database, allOps), - newParamLimiterFuncWithLimitFunc(internalpb.RateScope_Collection, allOps, getCollectionLimitVal)) - } - } - if len(collections) == 0 { - q.rateLimiter.GetOrCreateDatabaseLimiters(dbID, newParamLimiterFunc(internalpb.RateScope_Database, allOps)) } } } From 5420a3eaefccbc7d9bed8391a61817f9dba913c4 Mon Sep 17 00:00:00 2001 From: bigsheeper Date: Mon, 30 Dec 2024 19:48:26 +0800 Subject: [PATCH 2/2] fix Signed-off-by: bigsheeper --- internal/rootcoord/quota_center.go | 3 +++ 1 file changed, 3 insertions(+) diff --git a/internal/rootcoord/quota_center.go b/internal/rootcoord/quota_center.go index 511f465c65edb..4ccb21165435e 100644 --- a/internal/rootcoord/quota_center.go +++ b/internal/rootcoord/quota_center.go @@ -1216,6 +1216,9 @@ func (q *QuotaCenter) resetAllCurrentRates() error { newParamLimiterFunc(internalpb.RateScope_Partition, allOps)) } } + if len(collections) == 0 { + q.rateLimiter.GetOrCreateDatabaseLimiters(dbID, newParamLimiterFunc(internalpb.RateScope_Database, allOps)) + } } } initLimiters(q.readableCollections)