From f526609331ba5d6c2377135fdac3ff1dbe71c175 Mon Sep 17 00:00:00 2001 From: Mohammad Arshad Date: Tue, 17 May 2022 10:54:38 +0530 Subject: [PATCH] HBASE-26856 BufferedDataBlockEncoder.OnheapDecodedCell value can get corrupted Created OnheapDecodedCell and OffheapDecodedExtendedCell objects with duplicate copy of ByteBuffer's underlying array instead of original ByteBuffer Signed-off-by: Andrew Purtell Signed-off-by: Pankaj Kumar --- .../io/encoding/BufferedDataBlockEncoder.java | 24 +++++++++++++++---- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/hbase-common/src/main/java/org/apache/hadoop/hbase/io/encoding/BufferedDataBlockEncoder.java b/hbase-common/src/main/java/org/apache/hadoop/hbase/io/encoding/BufferedDataBlockEncoder.java index 8ab17285d9d9..06ec122e7429 100644 --- a/hbase-common/src/main/java/org/apache/hadoop/hbase/io/encoding/BufferedDataBlockEncoder.java +++ b/hbase-common/src/main/java/org/apache/hadoop/hbase/io/encoding/BufferedDataBlockEncoder.java @@ -232,9 +232,10 @@ private Cell toOnheapCell(ByteBuffer valAndTagsBuffer, int vOffset, int tOffset = 0; if (this.includeTags) { if (this.tagCompressionContext == null) { - tagsArray = valAndTagsBuffer.array(); tOffset = valAndTagsBuffer.arrayOffset() + vOffset + this.valueLength + tagsLenSerializationSize; + tagsArray = Bytes.copy(valAndTagsBuffer.array(), tOffset, this.tagsLength); + tOffset = 0; } else { tagsArray = Bytes.copy(tagsBuffer, 0, this.tagsLength); tOffset = 0; @@ -243,9 +244,9 @@ private Cell toOnheapCell(ByteBuffer valAndTagsBuffer, int vOffset, return new OnheapDecodedCell(Bytes.copy(keyBuffer, 0, this.keyLength), currentKey.getRowLength(), currentKey.getFamilyOffset(), currentKey.getFamilyLength(), currentKey.getQualifierOffset(), currentKey.getQualifierLength(), currentKey.getTimestamp(), - currentKey.getTypeByte(), valAndTagsBuffer.array(), - valAndTagsBuffer.arrayOffset() + vOffset, this.valueLength, memstoreTS, tagsArray, tOffset, - this.tagsLength); + currentKey.getTypeByte(), Bytes.copy(valAndTagsBuffer.array(), + valAndTagsBuffer.arrayOffset() + vOffset, this.valueLength), + 0, this.valueLength, memstoreTS, tagsArray, tOffset, this.tagsLength); } private Cell toOffheapCell(ByteBuffer valAndTagsBuffer, int vOffset, @@ -254,13 +255,26 @@ private Cell toOffheapCell(ByteBuffer valAndTagsBuffer, int vOffset, int tOffset = 0; if (this.includeTags) { if (this.tagCompressionContext == null) { - tagsBuf = valAndTagsBuffer; tOffset = vOffset + this.valueLength + tagsLenSerializationSize; + byte[] output = new byte[this.tagsLength]; + ByteBufferUtils.copyFromBufferToArray(output, valAndTagsBuffer, tOffset, 0, + this.tagsLength); + tagsBuf = ByteBuffer.wrap(output); + tOffset = 0; } else { tagsBuf = ByteBuffer.wrap(Bytes.copy(tagsBuffer, 0, this.tagsLength)); tOffset = 0; } } + + if (this.valueLength > 0) { + byte[] output = new byte[this.valueLength]; + ByteBufferUtils.copyFromBufferToArray(output, valAndTagsBuffer, vOffset, 0, + this.valueLength); + valAndTagsBuffer = ByteBuffer.wrap(output); + vOffset = 0; + } + return new OffheapDecodedExtendedCell( ByteBuffer.wrap(Bytes.copy(keyBuffer, 0, this.keyLength)), currentKey.getRowLength(), currentKey.getFamilyOffset(), currentKey.getFamilyLength(), currentKey.getQualifierOffset(),