HADOOP-18582. Addendum: Skip unnecessary cleanup logic in DistCp. (#5409)

Followup to the original HADOOP-18582.

Temporary path cleanup is re-enabled for -append jobs
as these will create temporary files when creating or overwriting files.

Contributed by Ayush Saxena
This commit is contained in:
Ayush Saxena 2023-02-23 00:59:41 +05:30 committed by Steve Loughran
parent ee71318d72
commit 84e999b35c
No known key found for this signature in database
GPG Key ID: D22CF846DBB162A0
2 changed files with 6 additions and 11 deletions

View File

@ -153,10 +153,7 @@ private void cleanupTempFiles(JobContext context) {
final boolean directWrite = conf.getBoolean( final boolean directWrite = conf.getBoolean(
DistCpOptionSwitch.DIRECT_WRITE.getConfigLabel(), false); DistCpOptionSwitch.DIRECT_WRITE.getConfigLabel(), false);
final boolean append = conf.getBoolean( if (directWrite) {
DistCpOptionSwitch.APPEND.getConfigLabel(), false);
final boolean useTempTarget = !append && !directWrite;
if (!useTempTarget) {
return; return;
} }

View File

@ -586,13 +586,11 @@ fs, new Path(targetBase + srcFilename),
@Test @Test
public void testCommitWithCleanupTempFiles() throws IOException { public void testCommitWithCleanupTempFiles() throws IOException {
testCommitWithCleanup(true, false); testCommitWithCleanup(true);
testCommitWithCleanup(false, true); testCommitWithCleanup(false);
testCommitWithCleanup(true, true);
testCommitWithCleanup(false, false);
} }
private void testCommitWithCleanup(boolean append, boolean directWrite)throws IOException { private void testCommitWithCleanup(boolean directWrite) throws IOException {
TaskAttemptContext taskAttemptContext = getTaskAttemptContext(config); TaskAttemptContext taskAttemptContext = getTaskAttemptContext(config);
JobID jobID = taskAttemptContext.getTaskAttemptID().getJobID(); JobID jobID = taskAttemptContext.getTaskAttemptID().getJobID();
JobContext jobContext = new JobContextImpl( JobContext jobContext = new JobContextImpl(
@ -611,7 +609,7 @@ private void testCommitWithCleanup(boolean append, boolean directWrite)throws IO
DistCpOptions options = new DistCpOptions.Builder( DistCpOptions options = new DistCpOptions.Builder(
Collections.singletonList(new Path(sourceBase)), Collections.singletonList(new Path(sourceBase)),
new Path("/out")) new Path("/out"))
.withAppend(append) .withAppend(true)
.withSyncFolder(true) .withSyncFolder(true)
.withDirectWrite(directWrite) .withDirectWrite(directWrite)
.build(); .build();
@ -631,7 +629,7 @@ private void testCommitWithCleanup(boolean append, boolean directWrite)throws IO
null, taskAttemptContext); null, taskAttemptContext);
committer.commitJob(jobContext); committer.commitJob(jobContext);
if (append || directWrite) { if (directWrite) {
ContractTestUtils.assertPathExists(fs, "Temp files should not be cleanup with append or direct option", ContractTestUtils.assertPathExists(fs, "Temp files should not be cleanup with append or direct option",
tempFilePath); tempFilePath);
} else { } else {