HBASE-12270 A bug in the bucket cache, with cache blocks on write enabled (Liu Shaohui)
This commit is contained in:
parent
ad7d7f5977
commit
2ff16e532b
|
@ -216,11 +216,11 @@ public class HFileBlock implements Cacheable {
|
||||||
this.uncompressedSizeWithoutHeader = uncompressedSizeWithoutHeader;
|
this.uncompressedSizeWithoutHeader = uncompressedSizeWithoutHeader;
|
||||||
this.prevBlockOffset = prevBlockOffset;
|
this.prevBlockOffset = prevBlockOffset;
|
||||||
this.buf = buf;
|
this.buf = buf;
|
||||||
if (fillHeader)
|
|
||||||
overwriteHeader();
|
|
||||||
this.offset = offset;
|
this.offset = offset;
|
||||||
this.onDiskDataSizeWithHeader = onDiskDataSizeWithHeader;
|
this.onDiskDataSizeWithHeader = onDiskDataSizeWithHeader;
|
||||||
this.fileContext = fileContext;
|
this.fileContext = fileContext;
|
||||||
|
if (fillHeader)
|
||||||
|
overwriteHeader();
|
||||||
this.buf.rewind();
|
this.buf.rewind();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -322,6 +322,11 @@ public class HFileBlock implements Cacheable {
|
||||||
buf.putInt(onDiskSizeWithoutHeader);
|
buf.putInt(onDiskSizeWithoutHeader);
|
||||||
buf.putInt(uncompressedSizeWithoutHeader);
|
buf.putInt(uncompressedSizeWithoutHeader);
|
||||||
buf.putLong(prevBlockOffset);
|
buf.putLong(prevBlockOffset);
|
||||||
|
if (this.fileContext.isUseHBaseChecksum()) {
|
||||||
|
buf.put(fileContext.getChecksumType().getCode());
|
||||||
|
buf.putInt(fileContext.getBytesPerChecksum());
|
||||||
|
buf.putInt(onDiskDataSizeWithHeader);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -1176,7 +1181,7 @@ public class HFileBlock implements Cacheable {
|
||||||
cacheConf.shouldCacheCompressed(blockType.getCategory()) ?
|
cacheConf.shouldCacheCompressed(blockType.getCategory()) ?
|
||||||
getOnDiskBufferWithHeader() :
|
getOnDiskBufferWithHeader() :
|
||||||
getUncompressedBufferWithHeader(),
|
getUncompressedBufferWithHeader(),
|
||||||
DONT_FILL_HEADER, startOffset,
|
FILL_HEADER, startOffset,
|
||||||
onDiskBytesWithHeader.length + onDiskChecksum.length, newContext);
|
onDiskBytesWithHeader.length + onDiskChecksum.length, newContext);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -37,6 +37,7 @@ import org.apache.commons.logging.LogFactory;
|
||||||
import org.apache.hadoop.conf.Configuration;
|
import org.apache.hadoop.conf.Configuration;
|
||||||
import org.apache.hadoop.fs.FileSystem;
|
import org.apache.hadoop.fs.FileSystem;
|
||||||
import org.apache.hadoop.fs.Path;
|
import org.apache.hadoop.fs.Path;
|
||||||
|
import org.apache.hadoop.hbase.Cell;
|
||||||
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
import org.apache.hadoop.hbase.HBaseTestingUtility;
|
||||||
import org.apache.hadoop.hbase.HColumnDescriptor;
|
import org.apache.hadoop.hbase.HColumnDescriptor;
|
||||||
import org.apache.hadoop.hbase.HConstants;
|
import org.apache.hadoop.hbase.HConstants;
|
||||||
|
@ -48,6 +49,7 @@ import org.apache.hadoop.hbase.client.Put;
|
||||||
import org.apache.hadoop.hbase.fs.HFileSystem;
|
import org.apache.hadoop.hbase.fs.HFileSystem;
|
||||||
import org.apache.hadoop.hbase.io.compress.Compression;
|
import org.apache.hadoop.hbase.io.compress.Compression;
|
||||||
import org.apache.hadoop.hbase.io.encoding.DataBlockEncoding;
|
import org.apache.hadoop.hbase.io.encoding.DataBlockEncoding;
|
||||||
|
import org.apache.hadoop.hbase.io.hfile.bucket.BucketCache;
|
||||||
import org.apache.hadoop.hbase.regionserver.BloomType;
|
import org.apache.hadoop.hbase.regionserver.BloomType;
|
||||||
import org.apache.hadoop.hbase.regionserver.HRegion;
|
import org.apache.hadoop.hbase.regionserver.HRegion;
|
||||||
import org.apache.hadoop.hbase.regionserver.StoreFile;
|
import org.apache.hadoop.hbase.regionserver.StoreFile;
|
||||||
|
@ -158,27 +160,48 @@ public class TestCacheOnWrite {
|
||||||
}
|
}
|
||||||
|
|
||||||
public TestCacheOnWrite(CacheOnWriteType cowType, Compression.Algorithm compress,
|
public TestCacheOnWrite(CacheOnWriteType cowType, Compression.Algorithm compress,
|
||||||
BlockEncoderTestType encoderType, boolean cacheCompressedData) {
|
BlockEncoderTestType encoderType, boolean cacheCompressedData, BlockCache blockCache) {
|
||||||
this.cowType = cowType;
|
this.cowType = cowType;
|
||||||
this.compress = compress;
|
this.compress = compress;
|
||||||
this.encoderType = encoderType;
|
this.encoderType = encoderType;
|
||||||
this.encoder = encoderType.getEncoder();
|
this.encoder = encoderType.getEncoder();
|
||||||
this.cacheCompressedData = cacheCompressedData;
|
this.cacheCompressedData = cacheCompressedData;
|
||||||
|
this.blockCache = blockCache;
|
||||||
testDescription = "[cacheOnWrite=" + cowType + ", compress=" + compress +
|
testDescription = "[cacheOnWrite=" + cowType + ", compress=" + compress +
|
||||||
", encoderType=" + encoderType + ", cacheCompressedData=" + cacheCompressedData + "]";
|
", encoderType=" + encoderType + ", cacheCompressedData=" + cacheCompressedData + "]";
|
||||||
System.out.println(testDescription);
|
System.out.println(testDescription);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static List<BlockCache> getBlockCaches() throws IOException {
|
||||||
|
Configuration conf = TEST_UTIL.getConfiguration();
|
||||||
|
List<BlockCache> blockcaches = new ArrayList<BlockCache>();
|
||||||
|
// default
|
||||||
|
blockcaches.add(new CacheConfig(conf).getBlockCache());
|
||||||
|
|
||||||
|
// memory
|
||||||
|
BlockCache lru = new LruBlockCache(128 * 1024 * 1024, 64 * 1024, TEST_UTIL.getConfiguration());
|
||||||
|
blockcaches.add(lru);
|
||||||
|
|
||||||
|
// bucket cache
|
||||||
|
FileSystem.get(conf).mkdirs(TEST_UTIL.getDataTestDir());
|
||||||
|
int[] bucketSizes = {INDEX_BLOCK_SIZE, DATA_BLOCK_SIZE, BLOOM_BLOCK_SIZE, 64 * 1024 };
|
||||||
|
BlockCache bucketcache =
|
||||||
|
new BucketCache("file:" + TEST_UTIL.getDataTestDir() + "/bucket.data",
|
||||||
|
128 * 1024 * 1024, 64 * 1024, bucketSizes, 5, 64 * 100, null);
|
||||||
|
blockcaches.add(bucketcache);
|
||||||
|
return blockcaches;
|
||||||
|
}
|
||||||
|
|
||||||
@Parameters
|
@Parameters
|
||||||
public static Collection<Object[]> getParameters() {
|
public static Collection<Object[]> getParameters() throws IOException {
|
||||||
List<Object[]> cowTypes = new ArrayList<Object[]>();
|
List<Object[]> cowTypes = new ArrayList<Object[]>();
|
||||||
for (CacheOnWriteType cowType : CacheOnWriteType.values()) {
|
for (BlockCache blockache : getBlockCaches()) {
|
||||||
for (Compression.Algorithm compress :
|
for (CacheOnWriteType cowType : CacheOnWriteType.values()) {
|
||||||
HBaseTestingUtility.COMPRESSION_ALGORITHMS) {
|
for (Compression.Algorithm compress : HBaseTestingUtility.COMPRESSION_ALGORITHMS) {
|
||||||
for (BlockEncoderTestType encoderType :
|
for (BlockEncoderTestType encoderType : BlockEncoderTestType.values()) {
|
||||||
BlockEncoderTestType.values()) {
|
for (boolean cacheCompressedData : new boolean[] { false, true }) {
|
||||||
for (boolean cacheCompressedData : new boolean[] { false, true }) {
|
cowTypes.add(new Object[] { cowType, compress, encoderType, cacheCompressedData, blockache});
|
||||||
cowTypes.add(new Object[] { cowType, compress, encoderType, cacheCompressedData });
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -194,17 +217,13 @@ public class TestCacheOnWrite {
|
||||||
conf.setInt(HFileBlockIndex.MAX_CHUNK_SIZE_KEY, INDEX_BLOCK_SIZE);
|
conf.setInt(HFileBlockIndex.MAX_CHUNK_SIZE_KEY, INDEX_BLOCK_SIZE);
|
||||||
conf.setInt(BloomFilterFactory.IO_STOREFILE_BLOOM_BLOCK_SIZE,
|
conf.setInt(BloomFilterFactory.IO_STOREFILE_BLOOM_BLOCK_SIZE,
|
||||||
BLOOM_BLOCK_SIZE);
|
BLOOM_BLOCK_SIZE);
|
||||||
conf.setBoolean(CacheConfig.CACHE_BLOCKS_ON_WRITE_KEY,
|
|
||||||
cowType.shouldBeCached(BlockType.DATA));
|
|
||||||
conf.setBoolean(CacheConfig.CACHE_INDEX_BLOCKS_ON_WRITE_KEY,
|
|
||||||
cowType.shouldBeCached(BlockType.LEAF_INDEX));
|
|
||||||
conf.setBoolean(CacheConfig.CACHE_BLOOM_BLOCKS_ON_WRITE_KEY,
|
|
||||||
cowType.shouldBeCached(BlockType.BLOOM_CHUNK));
|
|
||||||
conf.setBoolean(CacheConfig.CACHE_DATA_BLOCKS_COMPRESSED_KEY, cacheCompressedData);
|
conf.setBoolean(CacheConfig.CACHE_DATA_BLOCKS_COMPRESSED_KEY, cacheCompressedData);
|
||||||
cowType.modifyConf(conf);
|
cowType.modifyConf(conf);
|
||||||
fs = HFileSystem.get(conf);
|
fs = HFileSystem.get(conf);
|
||||||
cacheConf = new CacheConfig(conf);
|
cacheConf =
|
||||||
blockCache = cacheConf.getBlockCache();
|
new CacheConfig(blockCache, true, true, cowType.shouldBeCached(BlockType.DATA),
|
||||||
|
cowType.shouldBeCached(BlockType.LEAF_INDEX),
|
||||||
|
cowType.shouldBeCached(BlockType.BLOOM_CHUNK), false, cacheCompressedData, true, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
@After
|
@After
|
||||||
|
@ -308,6 +327,11 @@ public class TestCacheOnWrite {
|
||||||
assertEquals("{" + cachedDataBlockType
|
assertEquals("{" + cachedDataBlockType
|
||||||
+ "=1379, LEAF_INDEX=154, BLOOM_CHUNK=9, INTERMEDIATE_INDEX=18}", countByType);
|
+ "=1379, LEAF_INDEX=154, BLOOM_CHUNK=9, INTERMEDIATE_INDEX=18}", countByType);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// iterate all the keyvalue from hfile
|
||||||
|
while (scanner.next()) {
|
||||||
|
Cell cell = scanner.getKeyValue();
|
||||||
|
}
|
||||||
reader.close();
|
reader.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue