MAPREDUCE-7020. Task timeout in uber mode can crash AM. Contributed by Peter Bacsko
(cherry picked from commit 6eef3d7f1a
)
This commit is contained in:
parent
480b69c03c
commit
d7acc45ce4
|
@ -368,14 +368,16 @@ public class TaskAttemptListenerImpl extends CompositeService
|
||||||
org.apache.hadoop.mapreduce.v2.api.records.TaskAttemptId yarnAttemptID =
|
org.apache.hadoop.mapreduce.v2.api.records.TaskAttemptId yarnAttemptID =
|
||||||
TypeConverter.toYarn(taskAttemptID);
|
TypeConverter.toYarn(taskAttemptID);
|
||||||
|
|
||||||
|
AMFeedback feedback = new AMFeedback();
|
||||||
AtomicReference<TaskAttemptStatus> lastStatusRef =
|
AtomicReference<TaskAttemptStatus> lastStatusRef =
|
||||||
attemptIdToStatus.get(yarnAttemptID);
|
attemptIdToStatus.get(yarnAttemptID);
|
||||||
if (lastStatusRef == null) {
|
if (lastStatusRef == null) {
|
||||||
throw new IllegalStateException("Status update was called"
|
LOG.error("Status update was called with illegal TaskAttemptId: "
|
||||||
+ " with illegal TaskAttemptId: " + yarnAttemptID);
|
+ yarnAttemptID);
|
||||||
|
feedback.setTaskFound(false);
|
||||||
|
return feedback;
|
||||||
}
|
}
|
||||||
|
|
||||||
AMFeedback feedback = new AMFeedback();
|
|
||||||
feedback.setTaskFound(true);
|
feedback.setTaskFound(true);
|
||||||
|
|
||||||
// Propagating preemption to the task if TASK_PREEMPTION is enabled
|
// Propagating preemption to the task if TASK_PREEMPTION is enabled
|
||||||
|
|
|
@ -487,13 +487,15 @@ public class TestTaskAttemptListenerImpl {
|
||||||
assertEquals(Phase.REDUCE, status.phase);
|
assertEquals(Phase.REDUCE, status.phase);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test(expected = IllegalStateException.class)
|
@Test
|
||||||
public void testStatusUpdateFromUnregisteredTask()
|
public void testStatusUpdateFromUnregisteredTask()
|
||||||
throws IOException, InterruptedException{
|
throws IOException, InterruptedException{
|
||||||
configureMocks();
|
configureMocks();
|
||||||
startListener(false);
|
startListener(false);
|
||||||
|
|
||||||
listener.statusUpdate(attemptID, firstReduceStatus);
|
AMFeedback feedback = listener.statusUpdate(attemptID, firstReduceStatus);
|
||||||
|
|
||||||
|
assertFalse(feedback.getTaskFound());
|
||||||
}
|
}
|
||||||
|
|
||||||
private void configureMocks() {
|
private void configureMocks() {
|
||||||
|
|
|
@ -790,6 +790,9 @@ abstract public class Task implements Writable, Configurable {
|
||||||
long taskProgressInterval = MRJobConfUtil.
|
long taskProgressInterval = MRJobConfUtil.
|
||||||
getTaskProgressReportInterval(conf);
|
getTaskProgressReportInterval(conf);
|
||||||
|
|
||||||
|
boolean uberized = conf.getBoolean("mapreduce.task.uberized",
|
||||||
|
false);
|
||||||
|
|
||||||
while (!taskDone.get()) {
|
while (!taskDone.get()) {
|
||||||
synchronized (lock) {
|
synchronized (lock) {
|
||||||
done = false;
|
done = false;
|
||||||
|
@ -828,9 +831,14 @@ abstract public class Task implements Writable, Configurable {
|
||||||
// if Task Tracker is not aware of our task ID (probably because it died and
|
// if Task Tracker is not aware of our task ID (probably because it died and
|
||||||
// came back up), kill ourselves
|
// came back up), kill ourselves
|
||||||
if (!taskFound) {
|
if (!taskFound) {
|
||||||
LOG.warn("Parent died. Exiting "+taskId);
|
if (uberized) {
|
||||||
resetDoneFlag();
|
taskDone.set(true);
|
||||||
System.exit(66);
|
break;
|
||||||
|
} else {
|
||||||
|
LOG.warn("Parent died. Exiting "+taskId);
|
||||||
|
resetDoneFlag();
|
||||||
|
System.exit(66);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set a flag that says we should preempt this is read by
|
// Set a flag that says we should preempt this is read by
|
||||||
|
|
Loading…
Reference in New Issue