diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java index 503dfea20fe..55aa76c0bd0 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/HStore.java @@ -61,7 +61,6 @@ import org.apache.hadoop.fs.permission.FsAction; import org.apache.hadoop.hbase.Cell; import org.apache.hadoop.hbase.CellComparator; import org.apache.hadoop.hbase.CellUtil; -import org.apache.hadoop.hbase.CompoundConfiguration; import org.apache.hadoop.hbase.HConstants; import org.apache.hadoop.hbase.MemoryCompactionPolicy; import org.apache.hadoop.hbase.TableName; @@ -69,7 +68,6 @@ import org.apache.hadoop.hbase.backup.FailedArchiveException; import org.apache.hadoop.hbase.client.ColumnFamilyDescriptor; import org.apache.hadoop.hbase.client.RegionInfo; import org.apache.hadoop.hbase.client.Scan; -import org.apache.hadoop.hbase.client.TableDescriptor; import org.apache.hadoop.hbase.conf.ConfigurationManager; import org.apache.hadoop.hbase.conf.PropagatingConfigurationObserver; import org.apache.hadoop.hbase.coprocessor.ReadOnlyConfiguration; @@ -2627,10 +2625,11 @@ public class HStore implements Store, HeapSize, StoreConfigInformation, @Override public void onConfigurationChange(Configuration conf) { - this.conf = StoreUtils.createStoreConfiguration(conf, region.getTableDescriptor(), + Configuration storeConf = StoreUtils.createStoreConfiguration(conf, region.getTableDescriptor(), getColumnFamilyDescriptor()); - this.storeEngine.compactionPolicy.setConf(conf); - this.offPeakHours = OffPeakHours.getInstance(conf); + this.conf = storeConf; + this.storeEngine.compactionPolicy.setConf(storeConf); + this.offPeakHours = OffPeakHours.getInstance(storeConf); } /** diff --git a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHStore.java b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHStore.java index ed1206cd04f..abbff9426e2 100644 --- a/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHStore.java +++ b/hbase-server/src/test/java/org/apache/hadoop/hbase/regionserver/TestHStore.java @@ -54,7 +54,6 @@ import java.util.concurrent.atomic.AtomicInteger; import java.util.concurrent.atomic.AtomicLong; import java.util.concurrent.atomic.AtomicReference; import java.util.function.IntBinaryOperator; - import org.apache.hadoop.conf.Configuration; import org.apache.hadoop.fs.FSDataOutputStream; import org.apache.hadoop.fs.FileStatus; @@ -99,7 +98,6 @@ import org.apache.hadoop.hbase.io.hfile.HFileContextBuilder; import org.apache.hadoop.hbase.monitoring.MonitoredTask; import org.apache.hadoop.hbase.quotas.RegionSizeStoreImpl; import org.apache.hadoop.hbase.regionserver.MemStoreCompactionStrategy.Action; -import org.apache.hadoop.hbase.regionserver.TestHStore.MyDefaultMemStore; import org.apache.hadoop.hbase.regionserver.compactions.CompactionConfiguration; import org.apache.hadoop.hbase.regionserver.compactions.DefaultCompactor; import org.apache.hadoop.hbase.regionserver.querymatcher.ScanQueryMatcher; @@ -2281,6 +2279,29 @@ public class TestHStore { return segmentScanners.get(0); } + @Test + public void testOnConfigurationChange() throws IOException { + final int COMMON_MAX_FILES_TO_COMPACT = 10; + final int NEW_COMMON_MAX_FILES_TO_COMPACT = 8; + final int STORE_MAX_FILES_TO_COMPACT = 6; + + //Build a table that its maxFileToCompact different from common configuration. + Configuration conf = HBaseConfiguration.create(); + conf.setInt(CompactionConfiguration.HBASE_HSTORE_COMPACTION_MAX_KEY, + COMMON_MAX_FILES_TO_COMPACT); + ColumnFamilyDescriptor hcd = ColumnFamilyDescriptorBuilder.newBuilder(family) + .setConfiguration(CompactionConfiguration.HBASE_HSTORE_COMPACTION_MAX_KEY, + String.valueOf(STORE_MAX_FILES_TO_COMPACT)).build(); + init(this.name.getMethodName(), conf, hcd); + + //After updating common configuration, the conf in HStore itself must not be changed. + conf.setInt(CompactionConfiguration.HBASE_HSTORE_COMPACTION_MAX_KEY, + NEW_COMMON_MAX_FILES_TO_COMPACT); + this.store.onConfigurationChange(conf); + assertEquals(STORE_MAX_FILES_TO_COMPACT, + store.getStoreEngine().getCompactionPolicy().getConf().getMaxFilesToCompact()); + } + private HStoreFile mockStoreFileWithLength(long length) { HStoreFile sf = mock(HStoreFile.class); StoreFileReader sfr = mock(StoreFileReader.class);