HBASE-26476 Make DefaultMemStore extensible for HStore.memstore (#3869)
Signed-off-by: Duo Zhang <zhangduo@apache.org>
This commit is contained in:
parent
f86bff0f53
commit
b9b075f21a
|
@ -153,11 +153,8 @@ public class HStore implements Store, HeapSize, StoreConfigInformation,
|
|||
private static final int SPLIT_REGION_COMPACTION_PRIORITY = Integer.MIN_VALUE + 1000;
|
||||
|
||||
private static final Logger LOG = LoggerFactory.getLogger(HStore.class);
|
||||
/**
|
||||
* TODO:After making the {@link DefaultMemStore} extensible in {@link HStore} by HBASE-26476,we
|
||||
* change it back to final.
|
||||
*/
|
||||
protected MemStore memstore;
|
||||
|
||||
protected final MemStore memstore;
|
||||
// This stores directory in the filesystem.
|
||||
private final HRegion region;
|
||||
protected Configuration conf;
|
||||
|
@ -373,17 +370,21 @@ public class HStore implements Store, HeapSize, StoreConfigInformation,
|
|||
MemoryCompactionPolicy.valueOf(conf.get(CompactingMemStore.COMPACTING_MEMSTORE_TYPE_KEY,
|
||||
CompactingMemStore.COMPACTING_MEMSTORE_TYPE_DEFAULT).toUpperCase());
|
||||
}
|
||||
|
||||
switch (inMemoryCompaction) {
|
||||
case NONE:
|
||||
ms = ReflectionUtils.newInstance(DefaultMemStore.class,
|
||||
Class<? extends MemStore> memStoreClass =
|
||||
conf.getClass(MEMSTORE_CLASS_NAME, DefaultMemStore.class, MemStore.class);
|
||||
ms = ReflectionUtils.newInstance(memStoreClass,
|
||||
new Object[] { conf, getComparator(),
|
||||
this.getHRegion().getRegionServicesForStores()});
|
||||
break;
|
||||
default:
|
||||
Class<? extends CompactingMemStore> clz = conf.getClass(MEMSTORE_CLASS_NAME,
|
||||
CompactingMemStore.class, CompactingMemStore.class);
|
||||
ms = ReflectionUtils.newInstance(clz, new Object[]{conf, getComparator(), this,
|
||||
this.getHRegion().getRegionServicesForStores(), inMemoryCompaction});
|
||||
Class<? extends CompactingMemStore> compactingMemStoreClass =
|
||||
conf.getClass(MEMSTORE_CLASS_NAME, CompactingMemStore.class, CompactingMemStore.class);
|
||||
ms = ReflectionUtils.newInstance(compactingMemStoreClass,
|
||||
new Object[] { conf, getComparator(), this,
|
||||
this.getHRegion().getRegionServicesForStores(), inMemoryCompaction });
|
||||
}
|
||||
return ms;
|
||||
}
|
||||
|
|
|
@ -2206,9 +2206,7 @@ public class TestHStore {
|
|||
conf.setBoolean(WALFactory.WAL_ENABLED, false);
|
||||
|
||||
init(name.getMethodName(), conf, ColumnFamilyDescriptorBuilder.newBuilder(family).build());
|
||||
MyDefaultMemStore myDefaultMemStore = new MyDefaultMemStore(store.conf, store.getComparator(),
|
||||
store.getHRegion().getRegionServicesForStores());
|
||||
store.memstore = myDefaultMemStore;
|
||||
MyDefaultMemStore myDefaultMemStore = (MyDefaultMemStore) (store.memstore);
|
||||
myDefaultMemStore.store = store;
|
||||
|
||||
MemStoreSizing memStoreSizing = new NonThreadSafeMemStoreSizing();
|
||||
|
@ -2302,6 +2300,32 @@ public class TestHStore {
|
|||
store.getStoreEngine().getCompactionPolicy().getConf().getMaxFilesToCompact());
|
||||
}
|
||||
|
||||
/**
|
||||
* This test is for HBASE-26476
|
||||
*/
|
||||
@Test
|
||||
public void testExtendsDefaultMemStore() throws Exception {
|
||||
Configuration conf = HBaseConfiguration.create();
|
||||
conf.setBoolean(WALFactory.WAL_ENABLED, false);
|
||||
|
||||
init(name.getMethodName(), conf, ColumnFamilyDescriptorBuilder.newBuilder(family).build());
|
||||
assertTrue(this.store.memstore.getClass() == DefaultMemStore.class);
|
||||
tearDown();
|
||||
|
||||
conf.set(HStore.MEMSTORE_CLASS_NAME, CustomDefaultMemStore.class.getName());
|
||||
init(name.getMethodName(), conf, ColumnFamilyDescriptorBuilder.newBuilder(family).build());
|
||||
assertTrue(this.store.memstore.getClass() == CustomDefaultMemStore.class);
|
||||
}
|
||||
|
||||
static class CustomDefaultMemStore extends DefaultMemStore {
|
||||
|
||||
public CustomDefaultMemStore(Configuration conf, CellComparator c,
|
||||
RegionServicesForStores regionServices) {
|
||||
super(conf, c, regionServices);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
private HStoreFile mockStoreFileWithLength(long length) {
|
||||
HStoreFile sf = mock(HStoreFile.class);
|
||||
StoreFileReader sfr = mock(StoreFileReader.class);
|
||||
|
|
Loading…
Reference in New Issue