HBASE-16032 Possible memory leak in StoreScanner
This commit is contained in:
parent
a9950e0001
commit
471f942ec8
|
@ -5630,10 +5630,15 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
|||
List<KeyValueScanner> scanners = new ArrayList<KeyValueScanner>(scan.getFamilyMap().size());
|
||||
List<KeyValueScanner> joinedScanners
|
||||
= new ArrayList<KeyValueScanner>(scan.getFamilyMap().size());
|
||||
if (additionalScanners != null) {
|
||||
// Store all already instantiated scanners for exception handling
|
||||
List<KeyValueScanner> instantiatedScanners = new ArrayList<KeyValueScanner>();
|
||||
// handle additionalScanners
|
||||
if (additionalScanners != null && !additionalScanners.isEmpty()) {
|
||||
scanners.addAll(additionalScanners);
|
||||
instantiatedScanners.addAll(additionalScanners);
|
||||
}
|
||||
|
||||
try {
|
||||
for (Map.Entry<byte[], NavigableSet<byte[]>> entry : scan.getFamilyMap().entrySet()) {
|
||||
Store store = stores.get(entry.getKey());
|
||||
KeyValueScanner scanner;
|
||||
|
@ -5642,6 +5647,7 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
|||
} catch (FileNotFoundException e) {
|
||||
throw handleFileNotFound(e);
|
||||
}
|
||||
instantiatedScanners.add(scanner);
|
||||
if (this.filter == null || !scan.doLoadColumnFamiliesOnDemand()
|
||||
|| this.filter.isFamilyEssential(entry.getKey())) {
|
||||
scanners.add(scanner);
|
||||
|
@ -5650,6 +5656,13 @@ public class HRegion implements HeapSize, PropagatingConfigurationObserver, Regi
|
|||
}
|
||||
}
|
||||
initializeKVHeap(scanners, joinedScanners, region);
|
||||
} catch (IOException e) {
|
||||
// close all already instantiated scanners before throwing the exception
|
||||
for (KeyValueScanner scanner : instantiatedScanners) {
|
||||
scanner.close();
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
protected void initializeKVHeap(List<KeyValueScanner> scanners,
|
||||
|
|
|
@ -202,6 +202,7 @@ public class StoreScanner extends NonReversedNonLazyKeyValueScanner
|
|||
|
||||
this.store.addChangedReaderObserver(this);
|
||||
|
||||
try {
|
||||
// Pass columns to try to filter out unnecessary StoreFiles.
|
||||
List<KeyValueScanner> scanners = getScannersNoCompaction();
|
||||
|
||||
|
@ -209,8 +210,8 @@ public class StoreScanner extends NonReversedNonLazyKeyValueScanner
|
|||
// key does not exist, then to the start of the next matching Row).
|
||||
// Always check bloom filter to optimize the top row seek for delete
|
||||
// family marker.
|
||||
seekScanners(scanners, matcher.getStartKey(), explicitColumnQuery
|
||||
&& lazySeekEnabledGlobally, parallelSeekEnabled);
|
||||
seekScanners(scanners, matcher.getStartKey(), explicitColumnQuery && lazySeekEnabledGlobally,
|
||||
parallelSeekEnabled);
|
||||
|
||||
// set storeLimit
|
||||
this.storeLimit = scan.getMaxResultsPerColumnFamily();
|
||||
|
@ -220,6 +221,12 @@ public class StoreScanner extends NonReversedNonLazyKeyValueScanner
|
|||
addCurrentScanners(scanners);
|
||||
// Combine all seeked scanners with a heap
|
||||
resetKVHeap(scanners, store.getComparator());
|
||||
} catch (IOException e) {
|
||||
// remove us from the HStore#changedReaderObservers here or we'll have no chance to
|
||||
// and might cause memory leak
|
||||
this.store.deleteChangedReaderObserver(this);
|
||||
throw e;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
Loading…
Reference in New Issue