From 62c5424609ec802abe1037a885892837a2e1d587 Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Tue, 23 Jan 2024 16:15:15 +0800 Subject: [PATCH 1/6] fix region stats check Signed-off-by: Cabinfever_B --- pkg/cluster/cluster.go | 2 +- pkg/core/region.go | 21 ++--- pkg/core/region_test.go | 2 +- pkg/mcs/scheduling/server/cluster.go | 7 +- pkg/mcs/scheduling/server/grpc_service.go | 2 +- pkg/statistics/region_collection.go | 23 ++++-- pkg/syncer/client.go | 2 +- server/cluster/cluster.go | 11 +-- tests/server/cluster/cluster_test.go | 94 +++++++++++++++++++++++ 9 files changed, 133 insertions(+), 31 deletions(-) diff --git a/pkg/cluster/cluster.go b/pkg/cluster/cluster.go index 8809a706936..916200bfa3e 100644 --- a/pkg/cluster/cluster.go +++ b/pkg/cluster/cluster.go @@ -55,7 +55,7 @@ func HandleOverlaps(c Cluster, overlaps []*core.RegionInfo) { } // Collect collects the cluster information. -func Collect(c Cluster, region *core.RegionInfo, stores []*core.StoreInfo, hasRegionStats, isNew, isPrepared bool) { +func Collect(c Cluster, region *core.RegionInfo, stores []*core.StoreInfo, hasRegionStats bool) { if hasRegionStats { c.GetRegionStats().Observe(region, stores) } diff --git a/pkg/core/region.go b/pkg/core/region.go index b141e8478da..24503eab210 100644 --- a/pkg/core/region.go +++ b/pkg/core/region.go @@ -98,6 +98,12 @@ func (r *RegionInfo) LoadedFromStorage() bool { return r.source == Storage } +// LoadedFromSync means this region's meta info loaded from region syncer. +// Only used for test. +func (r *RegionInfo) LoadedFromSync() bool { + return r.source == Sync +} + // NewRegionInfo creates RegionInfo with region's meta and leader peer. func NewRegionInfo(region *metapb.Region, leader *metapb.Peer, opts ...RegionCreateOption) *RegionInfo { regionInfo := &RegionInfo{ @@ -705,7 +711,7 @@ func (r *RegionInfo) isRegionRecreated() bool { // RegionGuideFunc is a function that determines which follow-up operations need to be performed based on the origin // and new region information. -type RegionGuideFunc func(region, origin *RegionInfo) (isNew, saveKV, saveCache, needSync bool) +type RegionGuideFunc func(region, origin *RegionInfo) (saveKV, saveCache, needSync bool) // GenerateRegionGuideFunc is used to generate a RegionGuideFunc. Control the log output by specifying the log function. // nil means do not print the log. @@ -718,19 +724,16 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { } // Save to storage if meta is updated. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Mark isNew if the region in cache does not have leader. - return func(region, origin *RegionInfo) (isNew, saveKV, saveCache, needSync bool) { + // Now, no need to hols `isNew` because `saveCache` must be true if if the region in cache does not have leader. + return func(region, origin *RegionInfo) (saveKV, saveCache, needSync bool) { if origin == nil { if log.GetLevel() <= zap.DebugLevel { debug("insert new region", zap.Uint64("region-id", region.GetID()), logutil.ZapRedactStringer("meta-region", RegionToHexMeta(region.GetMeta()))) } - saveKV, saveCache, isNew = true, true, true + saveKV, saveCache = true, true } else { - if origin.LoadedFromStorage() { - isNew = true - } r := region.GetRegionEpoch() o := origin.GetRegionEpoch() if r.GetVersion() > o.GetVersion() { @@ -756,9 +759,7 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { saveKV, saveCache = true, true } if region.GetLeader().GetId() != origin.GetLeader().GetId() { - if origin.GetLeader().GetId() == 0 { - isNew = true - } else if log.GetLevel() <= zap.InfoLevel { + if log.GetLevel() <= zap.InfoLevel { info("leader changed", zap.Uint64("region-id", region.GetID()), zap.Uint64("from", origin.GetLeader().GetStoreId()), diff --git a/pkg/core/region_test.go b/pkg/core/region_test.go index 508e7aa59aa..1e3b6073dda 100644 --- a/pkg/core/region_test.go +++ b/pkg/core/region_test.go @@ -363,7 +363,7 @@ func TestNeedSync(t *testing.T) { for _, testCase := range testCases { regionA := region.Clone(testCase.optionsA...) regionB := region.Clone(testCase.optionsB...) - _, _, _, needSync := RegionGuide(regionA, regionB) + _, _, needSync := RegionGuide(regionA, regionB) re.Equal(testCase.needSync, needSync) } } diff --git a/pkg/mcs/scheduling/server/cluster.go b/pkg/mcs/scheduling/server/cluster.go index bbecad51f7c..ecf9f546d67 100644 --- a/pkg/mcs/scheduling/server/cluster.go +++ b/pkg/mcs/scheduling/server/cluster.go @@ -552,9 +552,8 @@ func (c *Cluster) processRegionHeartbeat(region *core.RegionInfo) error { hasRegionStats := c.regionStats != nil // Save to storage if meta is updated, except for flashback. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Mark isNew if the region in cache does not have leader. - isNew, _, saveCache, _ := core.GenerateRegionGuideFunc(true)(region, origin) - if !saveCache && !isNew { + _, saveCache, _ := core.GenerateRegionGuideFunc(true)(region, origin) + if !saveCache { // Due to some config changes need to update the region stats as well, // so we do some extra checks here. if hasRegionStats && c.regionStats.RegionStatsNeedUpdate(region) { @@ -576,7 +575,7 @@ func (c *Cluster) processRegionHeartbeat(region *core.RegionInfo) error { cluster.HandleOverlaps(c, overlaps) } - cluster.Collect(c, region, c.GetRegionStores(region), hasRegionStats, isNew, c.IsPrepared()) + cluster.Collect(c, region, c.GetRegionStores(region), hasRegionStats) return nil } diff --git a/pkg/mcs/scheduling/server/grpc_service.go b/pkg/mcs/scheduling/server/grpc_service.go index b865e917d75..9e9fb87fd7f 100644 --- a/pkg/mcs/scheduling/server/grpc_service.go +++ b/pkg/mcs/scheduling/server/grpc_service.go @@ -158,7 +158,7 @@ func (s *Service) RegionHeartbeat(stream schedulingpb.Scheduling_RegionHeartbeat s.hbStreams.BindStream(storeID, server) lastBind = time.Now() } - region := core.RegionFromHeartbeat(request, core.SetSource(core.Heartbeat)) + region := core.RegionFromHeartbeat(request) err = c.HandleRegionHeartbeat(region) if err != nil { // TODO: if we need to send the error back to API server. diff --git a/pkg/statistics/region_collection.go b/pkg/statistics/region_collection.go index 21af8e152fd..31f9e85b260 100644 --- a/pkg/statistics/region_collection.go +++ b/pkg/statistics/region_collection.go @@ -148,6 +148,9 @@ func (r *RegionStatistics) deleteEntry(deleteIndex RegionStatisticType, regionID // due to some special state types. func (r *RegionStatistics) RegionStatsNeedUpdate(region *core.RegionInfo) bool { regionID := region.GetID() + if !r.isObserved(regionID) { + return true + } if r.IsRegionStatsType(regionID, OversizedRegion) != region.IsOversized(int64(r.conf.GetRegionMaxSize()), int64(r.conf.GetRegionMaxKeys())) { return true @@ -156,6 +159,14 @@ func (r *RegionStatistics) RegionStatsNeedUpdate(region *core.RegionInfo) bool { region.NeedMerge(int64(r.conf.GetMaxMergeRegionSize()), int64(r.conf.GetMaxMergeRegionKeys())) } +// isObserved returns whether the region is observed. And it also shows whether PD recived heartbeat of this region. +func (r *RegionStatistics) isObserved(id uint64) bool { + r.RLock() + defer r.RUnlock() + _, ok := r.index[id] + return ok +} + // Observe records the current regions' status. func (r *RegionStatistics) Observe(region *core.RegionInfo, stores []*core.StoreInfo) { r.Lock() @@ -164,7 +175,6 @@ func (r *RegionStatistics) Observe(region *core.RegionInfo, stores []*core.Store desiredReplicas = r.conf.GetMaxReplicas() desiredVoters = desiredReplicas peerTypeIndex RegionStatisticType - deleteIndex RegionStatisticType ) // Check if the region meets count requirements of its rules. if r.conf.IsPlacementRulesEnabled() { @@ -240,10 +250,10 @@ func (r *RegionStatistics) Observe(region *core.RegionInfo, stores []*core.Store } } // Remove the info if any of the conditions are not met any more. - if oldIndex, ok := r.index[regionID]; ok { - deleteIndex = oldIndex &^ peerTypeIndex + if oldIndex, ok := r.index[regionID]; ok && oldIndex > 0 { + deleteIndex := oldIndex &^ peerTypeIndex + r.deleteEntry(deleteIndex, regionID) } - r.deleteEntry(deleteIndex, regionID) r.index[regionID] = peerTypeIndex } @@ -252,7 +262,10 @@ func (r *RegionStatistics) ClearDefunctRegion(regionID uint64) { r.Lock() defer r.Unlock() if oldIndex, ok := r.index[regionID]; ok { - r.deleteEntry(oldIndex, regionID) + delete(r.index, regionID) + if oldIndex > 0 { + r.deleteEntry(oldIndex, regionID) + } } } diff --git a/pkg/syncer/client.go b/pkg/syncer/client.go index 00dd8c5107d..cd9a87aaf54 100644 --- a/pkg/syncer/client.go +++ b/pkg/syncer/client.go @@ -205,7 +205,7 @@ func (s *RegionSyncer) StartSyncWithLeader(addr string) { log.Debug("region is stale", zap.Stringer("origin", origin.GetMeta()), errs.ZapError(err)) continue } - _, saveKV, _, _ := regionGuide(region, origin) + saveKV, _, _ := regionGuide(region, origin) overlaps := bc.PutRegion(region) if hasBuckets { diff --git a/server/cluster/cluster.go b/server/cluster/cluster.go index abb8af80a92..0bd549f8809 100644 --- a/server/cluster/cluster.go +++ b/server/cluster/cluster.go @@ -1004,9 +1004,8 @@ func (c *RaftCluster) processRegionHeartbeat(region *core.RegionInfo) error { hasRegionStats := c.regionStats != nil // Save to storage if meta is updated, except for flashback. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Mark isNew if the region in cache does not have leader. - isNew, saveKV, saveCache, needSync := regionGuide(region, origin) - if !saveKV && !saveCache && !isNew { + saveKV, saveCache, needSync := regionGuide(region, origin) + if !saveKV && !saveCache { // Due to some config changes need to update the region stats as well, // so we do some extra checks here. if hasRegionStats && c.regionStats.RegionStatsNeedUpdate(region) { @@ -1037,11 +1036,7 @@ func (c *RaftCluster) processRegionHeartbeat(region *core.RegionInfo) error { regionUpdateCacheEventCounter.Inc() } - isPrepared := true - if !c.IsServiceIndependent(mcsutils.SchedulingServiceName) { - isPrepared = c.IsPrepared() - } - cluster.Collect(c, region, c.GetRegionStores(region), hasRegionStats, isNew, isPrepared) + cluster.Collect(c, region, c.GetRegionStores(region), hasRegionStats) if c.storage != nil { // If there are concurrent heartbeats from the same region, the last write will win even if diff --git a/tests/server/cluster/cluster_test.go b/tests/server/cluster/cluster_test.go index 67c798d7f69..1265fe4c772 100644 --- a/tests/server/cluster/cluster_test.go +++ b/tests/server/cluster/cluster_test.go @@ -38,6 +38,7 @@ import ( sc "github.com/tikv/pd/pkg/schedule/config" "github.com/tikv/pd/pkg/schedule/operator" "github.com/tikv/pd/pkg/schedule/schedulers" + "github.com/tikv/pd/pkg/statistics" "github.com/tikv/pd/pkg/storage" "github.com/tikv/pd/pkg/syncer" "github.com/tikv/pd/pkg/tso" @@ -181,6 +182,99 @@ func TestDamagedRegion(t *testing.T) { re.Equal(uint64(1), rc.GetOperatorController().OperatorCount(operator.OpAdmin)) } +func TestRegionStatistics(t *testing.T) { + re := require.New(t) + ctx, cancel := context.WithCancel(context.Background()) + defer cancel() + tc, err := tests.NewTestCluster(ctx, 2) + defer tc.Destroy() + re.NoError(err) + + err = tc.RunInitialServers() + re.NoError(err) + + leaderName := tc.WaitLeader() + leaderServer := tc.GetLeaderServer() + grpcPDClient := testutil.MustNewGrpcClient(re, leaderServer.GetAddr()) + clusterID := leaderServer.GetClusterID() + bootstrapCluster(re, clusterID, grpcPDClient) + rc := leaderServer.GetRaftCluster() + + region := &metapb.Region{ + Id: 10, + StartKey: []byte("abc"), + EndKey: []byte("xyz"), + Peers: []*metapb.Peer{ + {Id: 101, StoreId: 1}, + {Id: 102, StoreId: 2}, + {Id: 103, StoreId: 3}, + {Id: 104, StoreId: 4, Role: metapb.PeerRole_Learner}, + }, + } + + // To put region. + regionInfo := core.NewRegionInfo(region, region.Peers[0], core.SetApproximateSize(0)) + err = tc.HandleRegionHeartbeat(regionInfo) + re.NoError(err) + regions := rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 1) + + // wait for sync region + time.Sleep(1000 * time.Millisecond) + + leaderServer.ResignLeader() + newLeaderName := tc.WaitLeader() + re.NotEqual(newLeaderName, leaderName) + leaderServer = tc.GetLeaderServer() + rc = leaderServer.GetRaftCluster() + r := rc.GetRegion(region.Id) + re.NotNil(r) + re.True(r.LoadedFromSync()) + regions = rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 0) + err = tc.HandleRegionHeartbeat(regionInfo) + re.NoError(err) + regions = rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 1) + + leaderServer.ResignLeader() + newLeaderName = tc.WaitLeader() + re.Equal(newLeaderName, leaderName) + leaderServer = tc.GetLeaderServer() + rc = leaderServer.GetRaftCluster() + re.NotNil(r) + re.True(r.LoadedFromStorage() || r.LoadedFromSync()) + regions = rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 0) + regionInfo = regionInfo.Clone(core.SetSource(core.Heartbeat), core.SetApproximateSize(30)) + err = tc.HandleRegionHeartbeat(regionInfo) + re.NoError(err) + rc = leaderServer.GetRaftCluster() + r = rc.GetRegion(region.Id) + re.NotNil(r) + re.False(r.LoadedFromStorage() && r.LoadedFromSync()) + + leaderServer.ResignLeader() + newLeaderName = tc.WaitLeader() + re.NotEqual(newLeaderName, leaderName) + leaderServer.ResignLeader() + newLeaderName = tc.WaitLeader() + re.Equal(newLeaderName, leaderName) + leaderServer = tc.GetLeaderServer() + rc = leaderServer.GetRaftCluster() + r = rc.GetRegion(region.Id) + re.NotNil(r) + re.False(r.LoadedFromStorage() && r.LoadedFromSync()) + regions = rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 0) + + regionInfo = regionInfo.Clone(core.SetSource(core.Heartbeat), core.SetApproximateSize(30)) + err = tc.HandleRegionHeartbeat(regionInfo) + re.NoError(err) + regions = rc.GetRegionStatsByType(statistics.LearnerPeer) + re.Len(regions, 1) +} + func TestStaleRegion(t *testing.T) { re := require.New(t) ctx, cancel := context.WithCancel(context.Background()) From 2d055ed68701724c987503e24b982b4b5209b4c2 Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Wed, 24 Jan 2024 11:29:29 +0800 Subject: [PATCH 2/6] fix region stats check Signed-off-by: Cabinfever_B --- pkg/statistics/region_collection.go | 2 +- server/api/region_test.go | 2 ++ server/cluster/cluster.go | 1 + tests/server/cluster/cluster_test.go | 6 +++--- 4 files changed, 7 insertions(+), 4 deletions(-) diff --git a/pkg/statistics/region_collection.go b/pkg/statistics/region_collection.go index 31f9e85b260..b30b6503e05 100644 --- a/pkg/statistics/region_collection.go +++ b/pkg/statistics/region_collection.go @@ -159,7 +159,7 @@ func (r *RegionStatistics) RegionStatsNeedUpdate(region *core.RegionInfo) bool { region.NeedMerge(int64(r.conf.GetMaxMergeRegionSize()), int64(r.conf.GetMaxMergeRegionKeys())) } -// isObserved returns whether the region is observed. And it also shows whether PD recived heartbeat of this region. +// isObserved returns whether the region is observed. And it also shows whether PD received heartbeat of this region. func (r *RegionStatistics) isObserved(id uint64) bool { r.RLock() defer r.RUnlock() diff --git a/server/api/region_test.go b/server/api/region_test.go index 4838e24d632..be7523bb822 100644 --- a/server/api/region_test.go +++ b/server/api/region_test.go @@ -211,6 +211,8 @@ func (suite *regionTestSuite) TestRegionCheck() { histKeys := []*histItem{{Start: 1000, End: 1999, Count: 1}} re.Equal(histKeys, r7) + // ref https://github.com/tikv/pd/issues/3558, we should change size to pass `NeedUpdate` for observing. + r = r.Clone(core.SetApproximateKeys(0)) mustPutStore(re, suite.svr, 2, metapb.StoreState_Offline, metapb.NodeState_Removing, []*metapb.StoreLabel{}) mustRegionHeartbeat(re, suite.svr, r) url = fmt.Sprintf("%s/regions/check/%s", suite.urlPrefix, "offline-peer") diff --git a/server/cluster/cluster.go b/server/cluster/cluster.go index 0bd549f8809..73842ec73eb 100644 --- a/server/cluster/cluster.go +++ b/server/cluster/cluster.go @@ -1005,6 +1005,7 @@ func (c *RaftCluster) processRegionHeartbeat(region *core.RegionInfo) error { // Save to storage if meta is updated, except for flashback. // Save to cache if meta or leader is updated, or contains any down/pending peer. saveKV, saveCache, needSync := regionGuide(region, origin) + fmt.Println("@@@@@", saveKV, saveCache, needSync) if !saveKV && !saveCache { // Due to some config changes need to update the region stats as well, // so we do some extra checks here. diff --git a/tests/server/cluster/cluster_test.go b/tests/server/cluster/cluster_test.go index 1265fe4c772..55b10fc3a4a 100644 --- a/tests/server/cluster/cluster_test.go +++ b/tests/server/cluster/cluster_test.go @@ -231,7 +231,7 @@ func TestRegionStatistics(t *testing.T) { re.NotNil(r) re.True(r.LoadedFromSync()) regions = rc.GetRegionStatsByType(statistics.LearnerPeer) - re.Len(regions, 0) + re.Empty(regions) err = tc.HandleRegionHeartbeat(regionInfo) re.NoError(err) regions = rc.GetRegionStatsByType(statistics.LearnerPeer) @@ -245,7 +245,7 @@ func TestRegionStatistics(t *testing.T) { re.NotNil(r) re.True(r.LoadedFromStorage() || r.LoadedFromSync()) regions = rc.GetRegionStatsByType(statistics.LearnerPeer) - re.Len(regions, 0) + re.Empty(regions) regionInfo = regionInfo.Clone(core.SetSource(core.Heartbeat), core.SetApproximateSize(30)) err = tc.HandleRegionHeartbeat(regionInfo) re.NoError(err) @@ -266,7 +266,7 @@ func TestRegionStatistics(t *testing.T) { re.NotNil(r) re.False(r.LoadedFromStorage() && r.LoadedFromSync()) regions = rc.GetRegionStatsByType(statistics.LearnerPeer) - re.Len(regions, 0) + re.Empty(regions) regionInfo = regionInfo.Clone(core.SetSource(core.Heartbeat), core.SetApproximateSize(30)) err = tc.HandleRegionHeartbeat(regionInfo) From c545ac851f127cdf588f7a5fc215dabe7a50018b Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Wed, 24 Jan 2024 11:45:03 +0800 Subject: [PATCH 3/6] address comment Signed-off-by: Cabinfever_B --- pkg/core/region.go | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/pkg/core/region.go b/pkg/core/region.go index 24503eab210..9a991a74c69 100644 --- a/pkg/core/region.go +++ b/pkg/core/region.go @@ -724,7 +724,7 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { } // Save to storage if meta is updated. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Now, no need to hols `isNew` because `saveCache` must be true if if the region in cache does not have leader. + // Now, no need to hold `isNew` because `saveCache` must be true if if the region in cache does not have leader. return func(region, origin *RegionInfo) (saveKV, saveCache, needSync bool) { if origin == nil { if log.GetLevel() <= zap.DebugLevel { @@ -759,7 +759,7 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { saveKV, saveCache = true, true } if region.GetLeader().GetId() != origin.GetLeader().GetId() { - if log.GetLevel() <= zap.InfoLevel { + if origin.GetLeader().GetId() != 0 && log.GetLevel() <= zap.InfoLevel { info("leader changed", zap.Uint64("region-id", region.GetID()), zap.Uint64("from", origin.GetLeader().GetStoreId()), From 77dfa24f1d79708e9f7b98807ec1dc6d580a9afc Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Wed, 24 Jan 2024 15:29:18 +0800 Subject: [PATCH 4/6] address comment Signed-off-by: Cabinfever_B --- pkg/core/region.go | 2 +- server/cluster/cluster.go | 1 - 2 files changed, 1 insertion(+), 2 deletions(-) diff --git a/pkg/core/region.go b/pkg/core/region.go index 9a991a74c69..777a2dff67f 100644 --- a/pkg/core/region.go +++ b/pkg/core/region.go @@ -724,7 +724,7 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { } // Save to storage if meta is updated. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Now, no need to hold `isNew` because `saveCache` must be true if if the region in cache does not have leader. + // Now, no need to hold `isNew` because `saveCache` must be true if the region in cache does not have leader. return func(region, origin *RegionInfo) (saveKV, saveCache, needSync bool) { if origin == nil { if log.GetLevel() <= zap.DebugLevel { diff --git a/server/cluster/cluster.go b/server/cluster/cluster.go index 73842ec73eb..0bd549f8809 100644 --- a/server/cluster/cluster.go +++ b/server/cluster/cluster.go @@ -1005,7 +1005,6 @@ func (c *RaftCluster) processRegionHeartbeat(region *core.RegionInfo) error { // Save to storage if meta is updated, except for flashback. // Save to cache if meta or leader is updated, or contains any down/pending peer. saveKV, saveCache, needSync := regionGuide(region, origin) - fmt.Println("@@@@@", saveKV, saveCache, needSync) if !saveKV && !saveCache { // Due to some config changes need to update the region stats as well, // so we do some extra checks here. From dfa0a645cd66d47aad1000cb762d0c634ec7cd88 Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Thu, 1 Feb 2024 17:36:29 +0800 Subject: [PATCH 5/6] address comment Signed-off-by: Cabinfever_B --- pkg/statistics/region_collection.go | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/pkg/statistics/region_collection.go b/pkg/statistics/region_collection.go index b30b6503e05..52655b093a2 100644 --- a/pkg/statistics/region_collection.go +++ b/pkg/statistics/region_collection.go @@ -33,6 +33,8 @@ type RegionInfoProvider interface { // RegionStatisticType represents the type of the region's status. type RegionStatisticType uint32 +const emptyStatistic = RegionStatisticType(0) + // region status type const ( MissPeer RegionStatisticType = 1 << iota @@ -250,7 +252,7 @@ func (r *RegionStatistics) Observe(region *core.RegionInfo, stores []*core.Store } } // Remove the info if any of the conditions are not met any more. - if oldIndex, ok := r.index[regionID]; ok && oldIndex > 0 { + if oldIndex, ok := r.index[regionID]; ok && oldIndex > emptyStatistic { deleteIndex := oldIndex &^ peerTypeIndex r.deleteEntry(deleteIndex, regionID) } @@ -263,7 +265,7 @@ func (r *RegionStatistics) ClearDefunctRegion(regionID uint64) { defer r.Unlock() if oldIndex, ok := r.index[regionID]; ok { delete(r.index, regionID) - if oldIndex > 0 { + if oldIndex > emptyStatistic { r.deleteEntry(oldIndex, regionID) } } From cf03d8c2493e28838cfda2dccf885418c290e777 Mon Sep 17 00:00:00 2001 From: Cabinfever_B Date: Thu, 1 Feb 2024 17:51:52 +0800 Subject: [PATCH 6/6] address comment Signed-off-by: Cabinfever_B --- pkg/core/region.go | 1 - 1 file changed, 1 deletion(-) diff --git a/pkg/core/region.go b/pkg/core/region.go index 777a2dff67f..0595e75f198 100644 --- a/pkg/core/region.go +++ b/pkg/core/region.go @@ -724,7 +724,6 @@ func GenerateRegionGuideFunc(enableLog bool) RegionGuideFunc { } // Save to storage if meta is updated. // Save to cache if meta or leader is updated, or contains any down/pending peer. - // Now, no need to hold `isNew` because `saveCache` must be true if the region in cache does not have leader. return func(region, origin *RegionInfo) (saveKV, saveCache, needSync bool) { if origin == nil { if log.GetLevel() <= zap.DebugLevel {