HBASE-27386 Use encoded size for calculating compression ratio in block size predicator (#4795)
Signed-off-by: Ankit Singhal <ankit@apache.org>
This commit is contained in:
parent
f8c0c35fce
commit
34f644095f
|
@ -933,7 +933,7 @@ public class HFileBlock implements Cacheable {
|
|||
// We need to cache the unencoded/uncompressed size before changing the block state
|
||||
int rawBlockSize = 0;
|
||||
if (this.getEncodingState() != null) {
|
||||
rawBlockSize = blockSizeWritten();
|
||||
rawBlockSize = encodedBlockSizeWritten();
|
||||
}
|
||||
// We need to set state before we can package the block up for cache-on-write. In a way, the
|
||||
// block is ready, but not yet encoded or compressed.
|
||||
|
|
|
@ -1216,8 +1216,8 @@ public class TestHStoreFile {
|
|||
public void testDataBlockSizeCompressed() throws Exception {
|
||||
conf.set(BLOCK_COMPRESSED_SIZE_PREDICATOR,
|
||||
PreviousBlockCompressionRatePredicator.class.getName());
|
||||
testDataBlockSizeWithCompressionRatePredicator(11,
|
||||
(s, c) -> (c > 1 && c < 11) ? s >= BLOCKSIZE_SMALL * 10 : true);
|
||||
testDataBlockSizeWithCompressionRatePredicator(12,
|
||||
(s, c) -> (c > 2 && c < 11) ? s >= BLOCKSIZE_SMALL * 10 : true);
|
||||
}
|
||||
|
||||
@Test
|
||||
|
|
Loading…
Reference in New Issue