HBASE-14591 Region with reference hfile may split after a forced split in IncreasingToUpperBoundRegionSplitPolicy
This commit is contained in:
parent
1960cb94db
commit
1a163b7ab7
|
@ -67,9 +67,7 @@ public class IncreasingToUpperBoundRegionSplitPolicy extends ConstantSizeRegionS
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected boolean shouldSplit() {
|
protected boolean shouldSplit() {
|
||||||
if (region.shouldForceSplit()) {
|
boolean force = region.shouldForceSplit();
|
||||||
return true;
|
|
||||||
}
|
|
||||||
boolean foundABigStore = false;
|
boolean foundABigStore = false;
|
||||||
// Get count of regions that have the same common table as this.region
|
// Get count of regions that have the same common table as this.region
|
||||||
int tableRegionsCount = getCountOfCommonTableRegions();
|
int tableRegionsCount = getCountOfCommonTableRegions();
|
||||||
|
@ -93,7 +91,7 @@ public class IncreasingToUpperBoundRegionSplitPolicy extends ConstantSizeRegionS
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
return foundABigStore;
|
return foundABigStore | force;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -60,6 +60,34 @@ public class TestRegionSplitPolicy {
|
||||||
Mockito.doReturn(stores).when(mockRegion).getStores();
|
Mockito.doReturn(stores).when(mockRegion).getStores();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void testForceSplitRegionWithReference() throws IOException {
|
||||||
|
htd.setMaxFileSize(1024L);
|
||||||
|
// Add a store above the requisite size. Should split.
|
||||||
|
HStore mockStore = Mockito.mock(HStore.class);
|
||||||
|
Mockito.doReturn(2000L).when(mockStore).getSize();
|
||||||
|
// Act as if there's a reference file or some other reason it can't split.
|
||||||
|
// This should prevent splitting even though it's big enough.
|
||||||
|
Mockito.doReturn(false).when(mockStore).canSplit();
|
||||||
|
stores.add(mockStore);
|
||||||
|
|
||||||
|
conf.set(HConstants.HBASE_REGION_SPLIT_POLICY_KEY,
|
||||||
|
ConstantSizeRegionSplitPolicy.class.getName());
|
||||||
|
ConstantSizeRegionSplitPolicy policy =
|
||||||
|
(ConstantSizeRegionSplitPolicy)RegionSplitPolicy.create(mockRegion, conf);
|
||||||
|
assertFalse(policy.shouldSplit());
|
||||||
|
Mockito.doReturn(true).when(mockRegion).shouldForceSplit();
|
||||||
|
assertFalse(policy.shouldSplit());
|
||||||
|
|
||||||
|
Mockito.doReturn(false).when(mockRegion).shouldForceSplit();
|
||||||
|
conf.set(HConstants.HBASE_REGION_SPLIT_POLICY_KEY,
|
||||||
|
IncreasingToUpperBoundRegionSplitPolicy.class.getName());
|
||||||
|
policy = (IncreasingToUpperBoundRegionSplitPolicy) RegionSplitPolicy.create(mockRegion, conf);
|
||||||
|
assertFalse(policy.shouldSplit());
|
||||||
|
Mockito.doReturn(true).when(mockRegion).shouldForceSplit();
|
||||||
|
assertFalse(policy.shouldSplit());
|
||||||
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void testIncreasingToUpperBoundRegionSplitPolicy() throws IOException {
|
public void testIncreasingToUpperBoundRegionSplitPolicy() throws IOException {
|
||||||
// Configure IncreasingToUpperBoundRegionSplitPolicy as our split policy
|
// Configure IncreasingToUpperBoundRegionSplitPolicy as our split policy
|
||||||
|
|
Loading…
Reference in New Issue