HBASE-12270 A bug in the bucket cache, with cache blocks on write enabled (Liu Shaohui)

This commit is contained in:
stack 2014-12-30 14:43:19 -08:00
parent ad7d7f5977
commit 2ff16e532b
2 changed files with 49 additions and 20 deletions

View File

@ -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);
} }
} }

View File

@ -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 (BlockCache blockache : getBlockCaches()) {
for (CacheOnWriteType cowType : CacheOnWriteType.values()) { for (CacheOnWriteType cowType : CacheOnWriteType.values()) {
for (Compression.Algorithm compress : for (Compression.Algorithm compress : HBaseTestingUtility.COMPRESSION_ALGORITHMS) {
HBaseTestingUtility.COMPRESSION_ALGORITHMS) { for (BlockEncoderTestType encoderType : BlockEncoderTestType.values()) {
for (BlockEncoderTestType encoderType :
BlockEncoderTestType.values()) {
for (boolean cacheCompressedData : new boolean[] { false, true }) { for (boolean cacheCompressedData : new boolean[] { false, true }) {
cowTypes.add(new Object[] { cowType, compress, encoderType, cacheCompressedData }); cowTypes.add(new Object[] { cowType, compress, encoderType, cacheCompressedData, blockache});
}
} }
} }
} }
@ -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();
} }