diff --git a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/compactions/Compactor.java b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/compactions/Compactor.java index 250825b23b27..312b79698c37 100644 --- a/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/compactions/Compactor.java +++ b/hbase-server/src/main/java/org/apache/hadoop/hbase/regionserver/compactions/Compactor.java @@ -321,11 +321,11 @@ protected final List compact(final CompactionRequestImpl request, dropCache = this.dropCacheMinor; } - List scanners = - createFileScanners(request.getFiles(), smallestReadPoint, dropCache); InternalScanner scanner = null; boolean finished = false; + List scanners = null; try { + scanners = createFileScanners(request.getFiles(), smallestReadPoint, dropCache); /* Include deletes, unless we are doing a major compaction */ ScanType scanType = scannerFactory.getScanType(request); ScanInfo scanInfo = preCompactScannerOpen(request, scanType, user); @@ -345,7 +345,18 @@ protected final List compact(final CompactionRequestImpl request, + store.getRegionInfo().getRegionNameAsString() + " because it was interrupted."); } } finally { - Closeables.close(scanner, true); + // createScanner may fail when seeking hfiles encounter Exception, e.g. even only one hfile + // reader encounters java.io.IOException: Invalid HFile block magic: + // \x00\x00\x00\x00\x00\x00\x00\x00 + // and then scanner will be null, but scanners for all the hfiles should be closed, + // or else we will find leak of ESTABLISHED sockets. + if (scanner == null && scanners != null) { + for (StoreFileScanner sfs : scanners) { + sfs.close(); + } + } else { + Closeables.close(scanner, true); + } if (!finished && writer != null) { abortWriter(writer); }