| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||
java.lang.Objectorg.apache.hadoop.hbase.regionserver.StoreFileScanner
@InterfaceAudience.LimitedPrivate(value="Coprocessor") public class StoreFileScanner
KeyValueScanner adaptor over the Reader. It also provides hooks into bloom filter things.
| Constructor Summary | |
|---|---|
| StoreFileScanner(StoreFile.Reader reader,
                 HFileScanner hfs,
                 boolean useMVCC)Implements a KeyValueScanneron top of the specifiedHFileScanner | |
| Method Summary | |
|---|---|
|  void | close()Close the KeyValue scanner. | 
|  void | enforceSeek()Does the real seek operation in case it was skipped by seekToRowCol(KeyValue, boolean) (TODO: Whats this?). | 
| static List<StoreFileScanner> | getScannersForStoreFiles(Collection<StoreFile> files,
                         boolean cacheBlocks,
                         boolean usePread)Return an array of scanners corresponding to the given set of store files. | 
| static List<StoreFileScanner> | getScannersForStoreFiles(Collection<StoreFile> files,
                         boolean cacheBlocks,
                         boolean usePread,
                         boolean isCompaction)Return an array of scanners corresponding to the given set of store files. | 
| static List<StoreFileScanner> | getScannersForStoreFiles(Collection<StoreFile> files,
                         boolean cacheBlocks,
                         boolean usePread,
                         boolean isCompaction,
                         ScanQueryMatcher matcher)Return an array of scanners corresponding to the given set of store files, And set the ScanQueryMatcher for each store file scanner for further optimization | 
|  long | getSequenceID()Get the sequence id associated with this KeyValueScanner. | 
|  boolean | isFileScanner() | 
|  KeyValue | next()Return the next KeyValue in this scanner, iterating the scanner | 
|  KeyValue | peek()Look at the next KeyValue in this scanner, but do not iterate scanner. | 
|  boolean | realSeekDone()We optimize our store scanners by checking the most recent store file first, so we sometimes pretend we have done a seek but delay it until the store scanner bubbles up to the top of the key-value heap. | 
|  boolean | requestSeek(KeyValue kv,
            boolean forward,
            boolean useBloom)Pretend we have done a seek but don't do it yet, if possible. | 
|  boolean | reseek(KeyValue key)Reseek the scanner at or after the specified KeyValue. | 
|  boolean | seek(KeyValue key)Seek the scanner at or after the specified KeyValue. | 
| static boolean | seekAtOrAfter(HFileScanner s,
              KeyValue k) | 
|  void | setScanQueryMatcher(ScanQueryMatcher matcher) | 
|  boolean | shouldUseScanner(Scan scan,
                 SortedSet<byte[]> columns,
                 long oldestUnexpiredTS)Allows to filter out scanners (both StoreFile and memstore) that we don't want to use based on criteria such as Bloom filters and timestamp ranges. | 
| protected  boolean | skipKVsNewerThanReadpoint() | 
|  String | toString() | 
| Methods inherited from class java.lang.Object | 
|---|
| clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait | 
| Constructor Detail | 
|---|
public StoreFileScanner(StoreFile.Reader reader,
                        HFileScanner hfs,
                        boolean useMVCC)
KeyValueScanner on top of the specified HFileScanner
hfs - HFile scanner| Method Detail | 
|---|
public static List<StoreFileScanner> getScannersForStoreFiles(Collection<StoreFile> files,
                                                              boolean cacheBlocks,
                                                              boolean usePread)
                                                       throws IOException
IOException
public static List<StoreFileScanner> getScannersForStoreFiles(Collection<StoreFile> files,
                                                              boolean cacheBlocks,
                                                              boolean usePread,
                                                              boolean isCompaction)
                                                       throws IOException
IOException
public static List<StoreFileScanner> getScannersForStoreFiles(Collection<StoreFile> files,
                                                              boolean cacheBlocks,
                                                              boolean usePread,
                                                              boolean isCompaction,
                                                              ScanQueryMatcher matcher)
                                                       throws IOException
IOExceptionpublic String toString()
toString in class Objectpublic KeyValue peek()
KeyValueScanner
peek in interface KeyValueScanner
public KeyValue next()
              throws IOException
KeyValueScanner
next in interface KeyValueScannerIOException
public boolean seek(KeyValue key)
             throws IOException
KeyValueScanner
seek in interface KeyValueScannerkey - seek value
IOException
public boolean reseek(KeyValue key)
               throws IOException
KeyValueScanner
reseek in interface KeyValueScannerkey - seek value (should be non-null)
IOException
protected boolean skipKVsNewerThanReadpoint()
                                     throws IOException
IOExceptionpublic void close()
KeyValueScanner
close in interface KeyValueScanner
public static boolean seekAtOrAfter(HFileScanner s,
                                    KeyValue k)
                             throws IOException
s - k - 
IOExceptionpublic long getSequenceID()
KeyValueScanner
getSequenceID in interface KeyValueScanner
public boolean requestSeek(KeyValue kv,
                           boolean forward,
                           boolean useBloom)
                    throws IOException
enforceSeek().
 Note that this function does guarantee that the current KV of this scanner will be advanced to at least the given KV. Because of this, it does have to do a real seek in cases when the seek timestamp is older than the highest timestamp of the file, e.g. when we are trying to seek to the next row/column and use OLDEST_TIMESTAMP in the seek key.
requestSeek in interface KeyValueScannerforward - do a forward-only "reseek" instead of a random-access seekuseBloom - whether to enable multi-column Bloom filter optimization
IOExceptionpublic boolean realSeekDone()
KeyValueScanner
realSeekDone in interface KeyValueScanner
public void enforceSeek()
                 throws IOException
KeyValueScannerKeyValueScanner.realSeekDone() first.
enforceSeek in interface KeyValueScannerIOExceptionpublic void setScanQueryMatcher(ScanQueryMatcher matcher)
public boolean isFileScanner()
isFileScanner in interface KeyValueScanner
public boolean shouldUseScanner(Scan scan,
                                SortedSet<byte[]> columns,
                                long oldestUnexpiredTS)
KeyValueScanner
shouldUseScanner in interface KeyValueScannerscan - the scan that we are selecting scanners forcolumns - the set of columns in the current column family, or null if
          not specified by the scanoldestUnexpiredTS - the oldest timestamp we are interested in for
          this query, based on TTL
| 
 | ||||||||||
| PREV CLASS NEXT CLASS | FRAMES NO FRAMES | |||||||||
| SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD | |||||||||