Mikhail Antonov created HBASE-15908:
---------------------------------------

             Summary: Checksum verification is broken
                 Key: HBASE-15908
                 URL: https://issues.apache.org/jira/browse/HBASE-15908
             Project: HBase
          Issue Type: Bug
          Components: HFile
    Affects Versions: 1.3.0
            Reporter: Mikhail Antonov


It looks like HBASE-11625 has broken checksum verification.

Caused by: org.apache.hadoop.hbase.io.hfile.CorruptHFileException: Problem 
reading HFile Trailer from file <file path>
        at 
org.apache.hadoop.hbase.io.hfile.HFile.pickReaderVersion(HFile.java:497)
        at org.apache.hadoop.hbase.io.hfile.HFile.createReader(HFile.java:525)
        at 
org.apache.hadoop.hbase.regionserver.StoreFile$Reader.<init>(StoreFile.java:1135)
        at 
org.apache.hadoop.hbase.regionserver.StoreFileInfo.open(StoreFileInfo.java:259)
        at 
org.apache.hadoop.hbase.regionserver.StoreFile.open(StoreFile.java:427)
        at 
org.apache.hadoop.hbase.regionserver.StoreFile.createReader(StoreFile.java:528)
        at 
org.apache.hadoop.hbase.regionserver.StoreFile.createReader(StoreFile.java:518)
        at 
org.apache.hadoop.hbase.regionserver.HStore.createStoreFileAndReader(HStore.java:652)
        at 
org.apache.hadoop.hbase.regionserver.HStore.access$000(HStore.java:117)
        at org.apache.hadoop.hbase.regionserver.HStore$1.call(HStore.java:519)
        at org.apache.hadoop.hbase.regionserver.HStore$1.call(HStore.java:516)
        ... 6 more
Caused by: java.lang.IllegalArgumentException: input ByteBuffers must be direct 
buffers
        at org.apache.hadoop.util.NativeCrc32.nativeComputeChunkedSums(Native 
Method)
        at 
org.apache.hadoop.util.NativeCrc32.verifyChunkedSums(NativeCrc32.java:59)
        at 
org.apache.hadoop.util.DataChecksum.verifyChunkedSums(DataChecksum.java:301)
        at 
org.apache.hadoop.hbase.io.hfile.ChecksumUtil.validateChecksum(ChecksumUtil.java:120)
        at 
org.apache.hadoop.hbase.io.hfile.HFileBlock$FSReaderImpl.validateChecksum(HFileBlock.java:1785)
        at 
org.apache.hadoop.hbase.io.hfile.HFileBlock$FSReaderImpl.readBlockDataInternal(HFileBlock.java:1728)
        at 
org.apache.hadoop.hbase.io.hfile.HFileBlock$FSReaderImpl.readBlockData(HFileBlock.java:1558)
        at 
org.apache.hadoop.hbase.io.hfile.HFileBlock$AbstractFSReader$1.nextBlock(HFileBlock.java:1397)
        at 
org.apache.hadoop.hbase.io.hfile.HFileBlock$AbstractFSReader$1.nextBlockWithBlockType(HFileBlock.java:1405)
        at 
org.apache.hadoop.hbase.io.hfile.HFileReaderV2.<init>(HFileReaderV2.java:151)
        at 
org.apache.hadoop.hbase.io.hfile.HFileReaderV3.<init>(HFileReaderV3.java:78)
        at 
org.apache.hadoop.hbase.io.hfile.HFile.pickReaderVersion(HFile.java:487)
        ... 16 more

Prior this change we won't use use native crc32 checksum verification as in 

DataChecksum#verifyChunkedSums we would go this codepath

if (data.hasArray() && checksums.hasArray()) {
  non-native checksum
}

So we were fine. However, now we're dropping below and try to use native crc32 
is one's available (and I think it's not in the tests), which expect 
DirectByteBuffer.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to