[fix][broker] Fix some problems in calculate totalAvailableBookies in method getExcludedBookiesWithIsolationGroups when some bookies belongs to multiple isolation groups. #24091
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
Motivation
Currently, the values of
totalAvailableBookiesInPrimaryGroup
andtotalAvailableBookiesFromPrimaryAndSecondary
may not be accurate because there may be repeated accumulation when some bookies belongs to multiple isolation groups.For example: There are 3 bookies in total and has 3 group, the distribution is as follows
Group1: bk1
Group2: bk2,bk3
Group3: bk1
When
primaryIsolationGroup
contains Group1 and Group3,secondaryIsolationGroup
contains Group2, when execute the methodgetExcludedBookiesWithIsolationGroups(2, groups[primaryIsolationGroup,secondaryIsolationGroup])
. The correct return value should be empty but current return bk2 and bk3.The calculation of
totalAvailableBookiesFromPrimaryAndSecondary
has similar problems.Modifications
Fix the calculation logic of
totalAvailableBookiesInPrimaryGroup
andtotalAvailableBookiesFromPrimaryAndSecondary
.Documentation
doc
doc-required
doc-not-needed
doc-complete