MAPREDUCE-2740. MultipleOutputs in new API creates needless TaskAttemptContexts. Contributed by Todd Lipcon.
git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1152875 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
54860d86ab
commit
22f232bce2
|
@ -212,6 +212,9 @@ Trunk (unreleased changes)
|
||||||
JobInProgress.getCounters() aquire locks in a shorter time period.
|
JobInProgress.getCounters() aquire locks in a shorter time period.
|
||||||
(Joydeep Sen Sarma via schen)
|
(Joydeep Sen Sarma via schen)
|
||||||
|
|
||||||
|
MAPREDUCE-2740. MultipleOutputs in new API creates needless
|
||||||
|
TaskAttemptContexts. (todd)
|
||||||
|
|
||||||
BUG FIXES
|
BUG FIXES
|
||||||
|
|
||||||
MAPREDUCE-2603. Disable High-Ram emulation in system tests.
|
MAPREDUCE-2603. Disable High-Ram emulation in system tests.
|
||||||
|
|
|
@ -132,6 +132,10 @@ public class MultipleOutputs<KEYOUT, VALUEOUT> {
|
||||||
* Cache for the taskContexts
|
* Cache for the taskContexts
|
||||||
*/
|
*/
|
||||||
private Map<String, TaskAttemptContext> taskContexts = new HashMap<String, TaskAttemptContext>();
|
private Map<String, TaskAttemptContext> taskContexts = new HashMap<String, TaskAttemptContext>();
|
||||||
|
/**
|
||||||
|
* Cached TaskAttemptContext which uses the job's configured settings
|
||||||
|
*/
|
||||||
|
private TaskAttemptContext jobOutputFormatContext;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Checks if a named output name is valid token.
|
* Checks if a named output name is valid token.
|
||||||
|
@ -382,11 +386,13 @@ public class MultipleOutputs<KEYOUT, VALUEOUT> {
|
||||||
public void write(KEYOUT key, VALUEOUT value, String baseOutputPath)
|
public void write(KEYOUT key, VALUEOUT value, String baseOutputPath)
|
||||||
throws IOException, InterruptedException {
|
throws IOException, InterruptedException {
|
||||||
checkBaseOutputPath(baseOutputPath);
|
checkBaseOutputPath(baseOutputPath);
|
||||||
TaskAttemptContext taskContext =
|
if (jobOutputFormatContext == null) {
|
||||||
|
jobOutputFormatContext =
|
||||||
new TaskAttemptContextImpl(context.getConfiguration(),
|
new TaskAttemptContextImpl(context.getConfiguration(),
|
||||||
context.getTaskAttemptID(),
|
context.getTaskAttemptID(),
|
||||||
new WrappedStatusReporter(context));
|
new WrappedStatusReporter(context));
|
||||||
getRecordWriter(taskContext, baseOutputPath).write(key, value);
|
}
|
||||||
|
getRecordWriter(jobOutputFormatContext, baseOutputPath).write(key, value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// by being synchronized MultipleOutputTask can be use with a
|
// by being synchronized MultipleOutputTask can be use with a
|
||||||
|
|
Loading…
Reference in New Issue