| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.hadoop.hbase.io.encoding.DiffKeyDeltaEncoder
@InterfaceAudience.Private public class DiffKeyDeltaEncoder
Compress using: - store size of common prefix - save column family once, it is same within HFile - use integer compression for key, value and prefix (7-bit encoding) - use bits to avoid duplication key length, value length and type if it same as previous - store in 3 bits length of timestamp field - allow diff in timestamp instead of actual value Format: - 1 byte: flag - 1-5 bytes: key length (only if FLAG_SAME_KEY_LENGTH is not set in flag) - 1-5 bytes: value length (only if FLAG_SAME_VALUE_LENGTH is not set in flag) - 1-5 bytes: prefix length - ... bytes: rest of the row (if prefix length is small enough) - ... bytes: qualifier (or suffix depending on prefix length) - 1-8 bytes: timestamp or diff - 1 byte: type (only if FLAG_SAME_TYPE is not set in the flag) - ... bytes: value
| Nested Class Summary | |
|---|---|
| protected static class | BufferedDataBlockEncoder.BufferedEncodedSeeker<STATE extends BufferedDataBlockEncoder.SeekerState> | 
| protected static class | BufferedDataBlockEncoder.SeekerState | 
| protected static class | DiffKeyDeltaEncoder.DiffCompressionState | 
| protected static class | DiffKeyDeltaEncoder.DiffSeekerState | 
| Nested classes/interfaces inherited from interface org.apache.hadoop.hbase.io.encoding.DataBlockEncoder | 
|---|
| DataBlockEncoder.EncodedSeeker | 
| Constructor Summary | |
|---|---|
| DiffKeyDeltaEncoder() | |
| Method Summary | |
|---|---|
| protected  void | afterDecodingKeyValue(DataInputStream source,
                      ByteBuffer dest,
                      boolean includesMemstoreTS) | 
| protected  void | afterEncodingKeyValue(ByteBuffer in,
                      DataOutputStream out,
                      boolean includesMemstoreTS) | 
|  DataBlockEncoder.EncodedSeeker | createSeeker(org.apache.hadoop.io.RawComparator<byte[]> comparator,
             boolean includesMemstoreTS)Create a HFileBlock seeker which find KeyValues within a block. | 
|  ByteBuffer | decodeKeyValues(DataInputStream source,
                boolean includesMemstoreTS)Decode. | 
|  ByteBuffer | decodeKeyValues(DataInputStream source,
                int allocHeaderLength,
                int skipLastBytes,
                boolean includesMemstoreTS)Uncompress. | 
|  void | encodeKeyValues(ByteBuffer in,
                boolean includesMemstoreTS,
                HFileBlockEncodingContext blkEncodingCtx)Encodes KeyValues. | 
| protected static void | ensureSpace(ByteBuffer out,
            int length)Asserts that there is at least the given amount of unfilled space remaining in the given buffer. | 
|  ByteBuffer | getFirstKeyInBlock(ByteBuffer block)Return first key in block. | 
|  void | internalEncodeKeyValues(DataOutputStream out,
                        ByteBuffer in,
                        boolean includesMemstoreTS)Compress KeyValues and write them to output buffer. | 
|  HFileBlockDecodingContext | newDataBlockDecodingContext(Compression.Algorithm compressionAlgorithm)Creates an encoder specific decoding context, which will prepare the data before actual decoding | 
|  HFileBlockEncodingContext | newDataBlockEncodingContext(Compression.Algorithm compressionAlgorithm,
                            DataBlockEncoding encoding,
                            byte[] header)Creates a encoder specific encoding context | 
|  String | toString() | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Constructor Detail | 
|---|
public DiffKeyDeltaEncoder()
| Method Detail | 
|---|
public void internalEncodeKeyValues(DataOutputStream out,
                                    ByteBuffer in,
                                    boolean includesMemstoreTS)
                             throws IOException
out - Where to write compressed data.in - Source of KeyValue for compression.includesMemstoreTS - true if including memstore timestamp after every
          key-value pair
IOException - If there is an error writing to output stream.
public ByteBuffer decodeKeyValues(DataInputStream source,
                                  int allocHeaderLength,
                                  int skipLastBytes,
                                  boolean includesMemstoreTS)
                           throws IOException
DataBlockEncoder
source - encoded stream of KeyValues.allocHeaderLength - allocate this many bytes for the header.skipLastBytes - Do not copy n last bytes.includesMemstoreTS - true if including memstore timestamp after every
          key-value pair
IOException - If there is an error in source.public ByteBuffer getFirstKeyInBlock(ByteBuffer block)
DataBlockEncoder
block - encoded block we want index, the position will not change
public String toString()
toString in class Object
public DataBlockEncoder.EncodedSeeker createSeeker(org.apache.hadoop.io.RawComparator<byte[]> comparator,
                                                   boolean includesMemstoreTS)
DataBlockEncoder
comparator - what kind of comparison should be usedincludesMemstoreTS - true if including memstore timestamp after every
          key-value pair
public ByteBuffer decodeKeyValues(DataInputStream source,
                                  boolean includesMemstoreTS)
                           throws IOException
DataBlockEncoder
decodeKeyValues in interface DataBlockEncodersource - Compressed stream of KeyValues.includesMemstoreTS - true if including memstore timestamp after every
          key-value pair
IOException - If there is an error in source.
protected final void afterEncodingKeyValue(ByteBuffer in,
                                           DataOutputStream out,
                                           boolean includesMemstoreTS)
protected final void afterDecodingKeyValue(DataInputStream source,
                                           ByteBuffer dest,
                                           boolean includesMemstoreTS)
public HFileBlockEncodingContext newDataBlockEncodingContext(Compression.Algorithm compressionAlgorithm,
                                                             DataBlockEncoding encoding,
                                                             byte[] header)
DataBlockEncoder
newDataBlockEncodingContext in interface DataBlockEncodercompressionAlgorithm - compression algorithm used if the final data needs to be
          compressedencoding - encoding strategy usedheader - header bytes to be written, put a dummy header here if the header
          is unknown
public HFileBlockDecodingContext newDataBlockDecodingContext(Compression.Algorithm compressionAlgorithm)
DataBlockEncoder
newDataBlockDecodingContext in interface DataBlockEncodercompressionAlgorithm - compression algorithm used if the data needs to be decompressed
public void encodeKeyValues(ByteBuffer in,
                            boolean includesMemstoreTS,
                            HFileBlockEncodingContext blkEncodingCtx)
                     throws IOException
DataBlockEncoder
encodeKeyValues in interface DataBlockEncoderin - Source of KeyValue for compression.includesMemstoreTS - true if including memstore timestamp after every key-value pairblkEncodingCtx - the encoding context which will contain encoded uncompressed bytes
          as well as compressed encoded bytes if compression is enabled, and
          also it will reuse resources across multiple calls.
IOException - If there is an error writing to output stream.
protected static void ensureSpace(ByteBuffer out,
                                  int length)
                           throws EncoderBufferTooSmallException
out - typically, the buffer we are writing tolength - the required space in the buffer
EncoderBufferTooSmallException - If there are no enough bytes.| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||