HBASE-12819 ExportSnapshot doesn't close FileSystem instances
This commit is contained in:
parent
29ec882a5e
commit
165bbb9e8d
|
@ -59,6 +59,7 @@ import org.apache.hadoop.hbase.protobuf.generated.SnapshotProtos.SnapshotRegionM
|
|||
import org.apache.hadoop.hbase.util.FSUtils;
|
||||
import org.apache.hadoop.hbase.util.Pair;
|
||||
import org.apache.hadoop.io.BytesWritable;
|
||||
import org.apache.hadoop.io.IOUtils;
|
||||
import org.apache.hadoop.io.NullWritable;
|
||||
import org.apache.hadoop.io.Writable;
|
||||
import org.apache.hadoop.mapreduce.Job;
|
||||
|
@ -152,12 +153,14 @@ public class ExportSnapshot extends Configured implements Tool {
|
|||
testFailures = conf.getBoolean(CONF_TEST_FAILURE, false);
|
||||
|
||||
try {
|
||||
conf.setBoolean("fs." + inputRoot.toUri().getScheme() + ".impl.disable.cache", true);
|
||||
inputFs = FileSystem.get(inputRoot.toUri(), conf);
|
||||
} catch (IOException e) {
|
||||
throw new IOException("Could not get the input FileSystem with root=" + inputRoot, e);
|
||||
}
|
||||
|
||||
try {
|
||||
conf.setBoolean("fs." + outputRoot.toUri().getScheme() + ".impl.disable.cache", true);
|
||||
outputFs = FileSystem.get(outputRoot.toUri(), conf);
|
||||
} catch (IOException e) {
|
||||
throw new IOException("Could not get the output FileSystem with root="+ outputRoot, e);
|
||||
|
@ -173,6 +176,12 @@ public class ExportSnapshot extends Configured implements Tool {
|
|||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void cleanup(Context context) {
|
||||
IOUtils.closeStream(inputFs);
|
||||
IOUtils.closeStream(outputFs);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void map(BytesWritable key, NullWritable value, Context context)
|
||||
throws InterruptedException, IOException {
|
||||
|
@ -854,8 +863,10 @@ public class ExportSnapshot extends Configured implements Tool {
|
|||
targetName = snapshotName;
|
||||
}
|
||||
|
||||
conf.setBoolean("fs." + inputRoot.toUri().getScheme() + ".impl.disable.cache", true);
|
||||
FileSystem inputFs = FileSystem.get(inputRoot.toUri(), conf);
|
||||
LOG.debug("inputFs=" + inputFs.getUri().toString() + " inputRoot=" + inputRoot);
|
||||
conf.setBoolean("fs." + outputRoot.toUri().getScheme() + ".impl.disable.cache", true);
|
||||
FileSystem outputFs = FileSystem.get(outputRoot.toUri(), conf);
|
||||
LOG.debug("outputFs=" + outputFs.getUri().toString() + " outputRoot=" + outputRoot.toString());
|
||||
|
||||
|
@ -949,6 +960,9 @@ public class ExportSnapshot extends Configured implements Tool {
|
|||
}
|
||||
outputFs.delete(outputSnapshotDir, true);
|
||||
return 1;
|
||||
} finally {
|
||||
IOUtils.closeStream(inputFs);
|
||||
IOUtils.closeStream(outputFs);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue