| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.hadoop.hbase.io.hfile.AbstractHFileReader
@InterfaceAudience.Private public abstract class AbstractHFileReader
Common functionality needed by all versions of HFile readers.
| Nested Class Summary | |
|---|---|
| static class | AbstractHFileReader.BlockIndexNotLoadedException | 
| static class | AbstractHFileReader.NotSeekedExceptionAn exception thrown when an operation requiring a scanner to be seeked is invoked on a scanner that is not seeked. | 
| protected static class | AbstractHFileReader.Scanner | 
| Field Summary | |
|---|---|
| protected  int | avgKeyLenAverage key length read from file info | 
| protected  int | avgValueLenAverage value length read from file info | 
| protected  CacheConfig | cacheConfBlock cache configuration. | 
| protected  org.apache.hadoop.io.RawComparator<byte[]> | comparatorKey comparator | 
| protected  Compression.Algorithm | compressAlgoFilled when we read in the trailer. | 
| protected  HFileDataBlockEncoder | dataBlockEncoderWhat kind of data block encoding should be used while reading, writing, and handling cache. | 
| protected  HFileBlockIndex.BlockIndexReader | dataBlockIndexReaderData block index reader keeping the root data index in memory | 
| protected  org.apache.hadoop.hbase.io.hfile.HFile.FileInfo | fileInfo | 
| protected  long | fileSizeSize of this file. | 
| protected  HFileSystem | hfsThe filesystem used for accesing data | 
| protected  org.apache.hadoop.fs.FSDataInputStream | istreamStream to read from. | 
| protected  org.apache.hadoop.fs.FSDataInputStream | istreamNoFsChecksumThe file system stream of the underlying HFilethat
 does not do checksum verification in the file system | 
| protected  byte[] | lastKeyLast key in the file. | 
| protected  HFileBlockIndex.BlockIndexReader | metaBlockIndexReaderMeta block index reader -- always single level | 
| protected  String | nameFile name to be used for block names | 
| protected  org.apache.hadoop.fs.Path | pathPath of file | 
| protected  FixedFileTrailer | trailer | 
| Constructor Summary | |
|---|---|
| protected  | AbstractHFileReader(org.apache.hadoop.fs.Path path,
                    FixedFileTrailer trailer,
                    long fileSize,
                    CacheConfig cacheConf,
                    HFileSystem hfs) | 
| Method Summary | |
|---|---|
|  org.apache.hadoop.io.RawComparator<byte[]> | getComparator() | 
|  Compression.Algorithm | getCompressionAlgorithm() | 
|  HFileBlockIndex.BlockIndexReader | getDataBlockIndexReader() | 
|  DataBlockEncoding | getEncodingOnDisk() | 
|  long | getEntries() | 
|  byte[] | getFirstKey() | 
|  byte[] | getFirstRowKey()TODO left from HFileversion 1: move this to StoreFile after Ryan's
 patch goes in to eliminateKeyValuehere. | 
|  byte[] | getLastRowKey()TODO left from HFileversion 1: move this to StoreFile after
 Ryan's patch goes in to eliminateKeyValuehere. | 
|  String | getName()Returns this reader's "name". | 
|  org.apache.hadoop.fs.Path | getPath() | 
|  HFileScanner | getScanner(boolean cacheBlocks,
           boolean pread)Create a Scanner on this file. | 
|  FixedFileTrailer | getTrailer() | 
|  long | indexSize() | 
| abstract  boolean | isFileInfoLoaded() | 
|  long | length() | 
|  org.apache.hadoop.hbase.io.hfile.HFile.FileInfo | loadFileInfo() | 
|  String | toString() | 
| protected  String | toStringFirstKey() | 
| protected  String | toStringLastKey() | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Methods inherited from interface org.apache.hadoop.hbase.io.hfile.HFile.Reader | 
|---|
| close, getDeleteBloomFilterMetadata, getGeneralBloomFilterMetadata, getLastKey, getMetaBlock, getScanner, midkey | 
| Methods inherited from interface java.io.Closeable | 
|---|
| close | 
| Methods inherited from interface org.apache.hadoop.hbase.io.hfile.HFile.CachingBlockReader | 
|---|
| readBlock | 
| Field Detail | 
|---|
protected org.apache.hadoop.fs.FSDataInputStream istream
protected org.apache.hadoop.fs.FSDataInputStream istreamNoFsChecksum
HFile that
 does not do checksum verification in the file system
protected HFileBlockIndex.BlockIndexReader dataBlockIndexReader
protected HFileBlockIndex.BlockIndexReader metaBlockIndexReader
protected final FixedFileTrailer trailer
protected final Compression.Algorithm compressAlgo
protected HFileDataBlockEncoder dataBlockEncoder
protected byte[] lastKey
protected int avgKeyLen
protected int avgValueLen
protected org.apache.hadoop.io.RawComparator<byte[]> comparator
protected final long fileSize
protected final CacheConfig cacheConf
protected final org.apache.hadoop.fs.Path path
protected final String name
protected org.apache.hadoop.hbase.io.hfile.HFile.FileInfo fileInfo
protected HFileSystem hfs
| Constructor Detail | 
|---|
protected AbstractHFileReader(org.apache.hadoop.fs.Path path,
                              FixedFileTrailer trailer,
                              long fileSize,
                              CacheConfig cacheConf,
                              HFileSystem hfs)
| Method Detail | 
|---|
protected String toStringFirstKey()
protected String toStringLastKey()
public abstract boolean isFileInfoLoaded()
public String toString()
toString in class Objectpublic long length()
length in interface HFile.Reader
public HFileScanner getScanner(boolean cacheBlocks,
                               boolean pread)
HFileScanner.seekTo(byte[]) to position an start the read. There is
 nothing to clean up in a Scanner. Letting go of your references to the
 scanner is sufficient. NOTE: Do not use this overload of getScanner for
 compactions.
getScanner in interface HFile.ReadercacheBlocks - True if we should cache blocks read in by this scanner.pread - Use positional read rather than seek+read if true (pread is
          better for random reads, seek+read is better scanning).
public byte[] getFirstKey()
getFirstKey in interface HFile.Readerpublic byte[] getFirstRowKey()
HFile version 1: move this to StoreFile after Ryan's
 patch goes in to eliminate KeyValue here.
getFirstRowKey in interface HFile.Readerpublic byte[] getLastRowKey()
HFile version 1: move this to StoreFile after
 Ryan's patch goes in to eliminate KeyValue here.
getLastRowKey in interface HFile.Readerpublic long getEntries()
getEntries in interface HFile.Readerpublic org.apache.hadoop.io.RawComparator<byte[]> getComparator()
getComparator in interface HFile.Readerpublic Compression.Algorithm getCompressionAlgorithm()
getCompressionAlgorithm in interface HFile.Readerpublic long indexSize()
indexSize in interface HFile.Readerpublic String getName()
HFile.Reader
getName in interface HFile.Readerpublic HFileBlockIndex.BlockIndexReader getDataBlockIndexReader()
getDataBlockIndexReader in interface HFile.Readerpublic FixedFileTrailer getTrailer()
getTrailer in interface HFile.Reader
public org.apache.hadoop.hbase.io.hfile.HFile.FileInfo loadFileInfo()
                                                             throws IOException
loadFileInfo in interface HFile.ReaderIOExceptionpublic org.apache.hadoop.fs.Path getPath()
getPath in interface HFile.Readerpublic DataBlockEncoding getEncodingOnDisk()
getEncodingOnDisk in interface HFile.Reader| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||