MAPREDUCE-7020. Task timeout in uber mode can crash AM. Contributed by Peter Bacsko
(cherry picked from commit e3a1647477
)
This commit is contained in:
parent
e062e2b08c
commit
d69df0b596
|
@ -342,8 +342,9 @@ public class TaskAttemptListenerImpl extends CompositeService
|
|||
AtomicReference<TaskAttemptStatus> lastStatusRef =
|
||||
attemptIdToStatus.get(yarnAttemptID);
|
||||
if (lastStatusRef == null) {
|
||||
throw new IllegalStateException("Status update was called"
|
||||
+ " with illegal TaskAttemptId: " + yarnAttemptID);
|
||||
LOG.error("Status update was called with illegal TaskAttemptId: "
|
||||
+ yarnAttemptID);
|
||||
return false;
|
||||
}
|
||||
|
||||
taskHeartbeatHandler.progressing(yarnAttemptID);
|
||||
|
|
|
@ -397,13 +397,15 @@ public class TestTaskAttemptListenerImpl {
|
|||
assertEquals(Phase.REDUCE, status.phase);
|
||||
}
|
||||
|
||||
@Test(expected = IllegalStateException.class)
|
||||
@Test
|
||||
public void testStatusUpdateFromUnregisteredTask()
|
||||
throws IOException, InterruptedException{
|
||||
configureMocks();
|
||||
startListener(false);
|
||||
|
||||
listener.statusUpdate(attemptID, firstReduceStatus);
|
||||
boolean taskFound = listener.statusUpdate(attemptID, firstReduceStatus);
|
||||
|
||||
assertFalse(taskFound);
|
||||
}
|
||||
|
||||
private void configureMocks() {
|
||||
|
|
|
@ -785,6 +785,9 @@ abstract public class Task implements Writable, Configurable {
|
|||
long taskProgressInterval = MRJobConfUtil.
|
||||
getTaskProgressReportInterval(conf);
|
||||
|
||||
boolean uberized = conf.getBoolean("mapreduce.task.uberized",
|
||||
false);
|
||||
|
||||
while (!taskDone.get()) {
|
||||
synchronized (lock) {
|
||||
done = false;
|
||||
|
@ -820,10 +823,15 @@ abstract public class Task implements Writable, Configurable {
|
|||
// if Task Tracker is not aware of our task ID (probably because it died and
|
||||
// came back up), kill ourselves
|
||||
if (!taskFound) {
|
||||
if (uberized) {
|
||||
taskDone.set(true);
|
||||
break;
|
||||
} else {
|
||||
LOG.warn("Parent died. Exiting "+taskId);
|
||||
resetDoneFlag();
|
||||
System.exit(66);
|
||||
}
|
||||
}
|
||||
|
||||
sendProgress = resetProgressFlag();
|
||||
remainingRetries = MAX_RETRIES;
|
||||
|
|
Loading…
Reference in New Issue