HADOOP-15850. CopyCommitter#concatFileChunks should check that the blocks per chunk is not 0. Contributed by Ted Yu.
Signed-off-by: Wei-Chiu Chuang <weichiu@apache.org> (cherry picked from commite2cecb681e
) (cherry picked from commita7dd244a49
) modified: hadoop-tools/hadoop-distcp/src/main/java/org/apache/hadoop/tools/mapred/CopyCommitter.java (cherry picked from commit84726679f0
) (cherry picked from commit8360d15abc
)
This commit is contained in:
parent
ca699774a2
commit
f2739f3f59
|
@ -68,6 +68,7 @@ public class CopyCommitter extends FileOutputCommitter {
|
|||
private boolean overwrite = false;
|
||||
private boolean targetPathExists = true;
|
||||
private boolean ignoreFailures = false;
|
||||
private int blocksPerChunk = 0;
|
||||
|
||||
/**
|
||||
* Create a output committer
|
||||
|
@ -78,6 +79,9 @@ public class CopyCommitter extends FileOutputCommitter {
|
|||
*/
|
||||
public CopyCommitter(Path outputPath, TaskAttemptContext context) throws IOException {
|
||||
super(outputPath, context);
|
||||
blocksPerChunk = context.getConfiguration().getInt(
|
||||
DistCpOptionSwitch.BLOCKS_PER_CHUNK.getConfigLabel(), 0);
|
||||
LOG.debug("blocks per chunk " + blocksPerChunk);
|
||||
this.taskAttemptContext = context;
|
||||
}
|
||||
|
||||
|
@ -92,7 +96,9 @@ public class CopyCommitter extends FileOutputCommitter {
|
|||
ignoreFailures = conf.getBoolean(
|
||||
DistCpOptionSwitch.IGNORE_FAILURES.getConfigLabel(), false);
|
||||
|
||||
concatFileChunks(conf);
|
||||
if (blocksPerChunk > 0) {
|
||||
concatFileChunks(conf);
|
||||
}
|
||||
|
||||
super.commitJob(jobContext);
|
||||
|
||||
|
|
|
@ -81,10 +81,6 @@ public class TestCopyCommitter {
|
|||
@Before
|
||||
public void createMetaFolder() {
|
||||
config.set(DistCpConstants.CONF_LABEL_META_FOLDER, "/meta");
|
||||
// Unset listing file path since the config is shared by
|
||||
// multiple tests, and some test doesn't set it, such as
|
||||
// testNoCommitAction, but the distcp code will check it.
|
||||
config.set(DistCpConstants.CONF_LABEL_LISTING_FILE_PATH, "");
|
||||
Path meta = new Path("/meta");
|
||||
try {
|
||||
cluster.getFileSystem().mkdirs(meta);
|
||||
|
|
Loading…
Reference in New Issue