HBASE-14257 Periodic flusher only handles hbase:meta, not other system tables. (Abhishek)
This commit is contained in:
parent
6382e975dc
commit
51bfd722c3
|
@ -1309,7 +1309,8 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
|||
"hbase.regionserver.optionalcacheflushinterval";
|
||||
/** Default interval for the memstore flush */
|
||||
public static final int DEFAULT_CACHE_FLUSH_INTERVAL = 3600000;
|
||||
public static final int META_CACHE_FLUSH_INTERVAL = 300000; // 5 minutes
|
||||
/** Default interval for System tables memstore flush */
|
||||
public static final int SYSTEM_CACHE_FLUSH_INTERVAL = 300000; // 5 minutes
|
||||
|
||||
/** Conf key to force a flush if there are already enough changes for one region in memstore */
|
||||
public static final String MEMSTORE_FLUSH_PER_CHANGES =
|
||||
|
@ -1997,9 +1998,9 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
|||
return true;
|
||||
}
|
||||
long modifiedFlushCheckInterval = flushCheckInterval;
|
||||
if (getRegionInfo().isMetaRegion() &&
|
||||
if (getRegionInfo().isSystemTable() &&
|
||||
getRegionInfo().getReplicaId() == HRegionInfo.DEFAULT_REPLICA_ID) {
|
||||
modifiedFlushCheckInterval = META_CACHE_FLUSH_INTERVAL;
|
||||
modifiedFlushCheckInterval = SYSTEM_CACHE_FLUSH_INTERVAL;
|
||||
}
|
||||
if (modifiedFlushCheckInterval <= 0) { //disabled
|
||||
return false;
|
||||
|
|
|
@ -940,10 +940,10 @@ public class TestDefaultMemStore extends TestCase {
|
|||
|
||||
public void testShouldFlushMeta() throws Exception {
|
||||
// write an edit in the META and ensure the shouldFlush (that the periodic memstore
|
||||
// flusher invokes) returns true after META_CACHE_FLUSH_INTERVAL (even though
|
||||
// flusher invokes) returns true after SYSTEM_CACHE_FLUSH_INTERVAL (even though
|
||||
// the MEMSTORE_PERIODIC_FLUSH_INTERVAL is set to a higher value)
|
||||
Configuration conf = new Configuration();
|
||||
conf.setInt(HRegion.MEMSTORE_PERIODIC_FLUSH_INTERVAL, HRegion.META_CACHE_FLUSH_INTERVAL * 10);
|
||||
conf.setInt(HRegion.MEMSTORE_PERIODIC_FLUSH_INTERVAL, HRegion.SYSTEM_CACHE_FLUSH_INTERVAL * 10);
|
||||
HBaseTestingUtility hbaseUtility = HBaseTestingUtility.createLocalHTU(conf);
|
||||
Path testDir = hbaseUtility.getDataTestDir();
|
||||
EnvironmentEdgeForMemstoreTest edge = new EnvironmentEdgeForMemstoreTest();
|
||||
|
@ -965,7 +965,7 @@ public class TestDefaultMemStore extends TestCase {
|
|||
edge.setCurrentTimeMillis(1234 + 100);
|
||||
StringBuffer sb = new StringBuffer();
|
||||
assertTrue(meta.shouldFlush(sb) == false);
|
||||
edge.setCurrentTimeMillis(edge.currentTime() + HRegion.META_CACHE_FLUSH_INTERVAL + 1);
|
||||
edge.setCurrentTimeMillis(edge.currentTime() + HRegion.SYSTEM_CACHE_FLUSH_INTERVAL + 1);
|
||||
assertTrue(meta.shouldFlush(sb) == true);
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue