YARN-5476. Non existent application reported as ACCEPTED by YarnClientImpl (Junping Du via Varun Saxena)
This commit is contained in:
parent
b63d3dcac9
commit
918a0f12fa
|
@ -833,8 +833,9 @@ public class RMAppImpl implements RMApp, Recoverable {
|
||||||
this.nextAttemptId = firstAttemptIdInStateStore;
|
this.nextAttemptId = firstAttemptIdInStateStore;
|
||||||
}
|
}
|
||||||
|
|
||||||
// send the ATS create Event
|
// send the ATS create Event during RM recovery.
|
||||||
sendATSCreateEvent(this, this.startTime);
|
// NOTE: it could be duplicated with events sent before RM get restarted.
|
||||||
|
sendATSCreateEvent();
|
||||||
|
|
||||||
RMAppAttemptImpl preAttempt = null;
|
RMAppAttemptImpl preAttempt = null;
|
||||||
for (ApplicationAttemptId attemptId :
|
for (ApplicationAttemptId attemptId :
|
||||||
|
@ -1049,6 +1050,8 @@ public class RMAppImpl implements RMApp, Recoverable {
|
||||||
public void transition(RMAppImpl app, RMAppEvent event) {
|
public void transition(RMAppImpl app, RMAppEvent event) {
|
||||||
app.handler.handle(new AppAddedSchedulerEvent(app.user,
|
app.handler.handle(new AppAddedSchedulerEvent(app.user,
|
||||||
app.submissionContext, false));
|
app.submissionContext, false));
|
||||||
|
// send the ATS create Event
|
||||||
|
app.sendATSCreateEvent();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1127,9 +1130,6 @@ public class RMAppImpl implements RMApp, Recoverable {
|
||||||
// communication
|
// communication
|
||||||
LOG.info("Storing application with id " + app.applicationId);
|
LOG.info("Storing application with id " + app.applicationId);
|
||||||
app.rmContext.getStateStore().storeNewApplication(app);
|
app.rmContext.getStateStore().storeNewApplication(app);
|
||||||
|
|
||||||
// send the ATS create Event
|
|
||||||
app.sendATSCreateEvent(app, app.startTime);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1827,9 +1827,9 @@ public class RMAppImpl implements RMApp, Recoverable {
|
||||||
return callerContext;
|
return callerContext;
|
||||||
}
|
}
|
||||||
|
|
||||||
private void sendATSCreateEvent(RMApp app, long startTime) {
|
private void sendATSCreateEvent() {
|
||||||
rmContext.getRMApplicationHistoryWriter().applicationStarted(app);
|
rmContext.getRMApplicationHistoryWriter().applicationStarted(this);
|
||||||
rmContext.getSystemMetricsPublisher().appCreated(app, startTime);
|
rmContext.getSystemMetricsPublisher().appCreated(this, this.startTime);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Private
|
@Private
|
||||||
|
|
|
@ -20,6 +20,7 @@ package org.apache.hadoop.yarn.server.resourcemanager.rmapp;
|
||||||
|
|
||||||
import static org.mockito.Matchers.any;
|
import static org.mockito.Matchers.any;
|
||||||
import static org.mockito.Matchers.anyLong;
|
import static org.mockito.Matchers.anyLong;
|
||||||
|
import static org.mockito.Matchers.eq;
|
||||||
import static org.mockito.Mockito.doReturn;
|
import static org.mockito.Mockito.doReturn;
|
||||||
import static org.mockito.Mockito.mock;
|
import static org.mockito.Mockito.mock;
|
||||||
import static org.mockito.Mockito.reset;
|
import static org.mockito.Mockito.reset;
|
||||||
|
@ -369,25 +370,32 @@ public class TestRMAppTransitions {
|
||||||
|
|
||||||
protected RMApp testCreateAppNewSaving(
|
protected RMApp testCreateAppNewSaving(
|
||||||
ApplicationSubmissionContext submissionContext) throws IOException {
|
ApplicationSubmissionContext submissionContext) throws IOException {
|
||||||
RMApp application = createNewTestApp(submissionContext);
|
RMApp application = createNewTestApp(submissionContext);
|
||||||
// NEW => NEW_SAVING event RMAppEventType.START
|
// NEW => NEW_SAVING event RMAppEventType.START
|
||||||
RMAppEvent event =
|
RMAppEvent event =
|
||||||
new RMAppEvent(application.getApplicationId(), RMAppEventType.START);
|
new RMAppEvent(application.getApplicationId(), RMAppEventType.START);
|
||||||
application.handle(event);
|
application.handle(event);
|
||||||
assertStartTimeSet(application);
|
assertStartTimeSet(application);
|
||||||
assertAppState(RMAppState.NEW_SAVING, application);
|
assertAppState(RMAppState.NEW_SAVING, application);
|
||||||
|
// verify sendATSCreateEvent() is not get called during
|
||||||
|
// RMAppNewlySavingTransition.
|
||||||
|
verify(publisher, times(0)).appCreated(eq(application), anyLong());
|
||||||
return application;
|
return application;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected RMApp testCreateAppSubmittedNoRecovery(
|
protected RMApp testCreateAppSubmittedNoRecovery(
|
||||||
ApplicationSubmissionContext submissionContext) throws IOException {
|
ApplicationSubmissionContext submissionContext) throws IOException {
|
||||||
RMApp application = testCreateAppNewSaving(submissionContext);
|
RMApp application = testCreateAppNewSaving(submissionContext);
|
||||||
// NEW_SAVING => SUBMITTED event RMAppEventType.APP_SAVED
|
// NEW_SAVING => SUBMITTED event RMAppEventType.APP_NEW_SAVED
|
||||||
RMAppEvent event =
|
RMAppEvent event =
|
||||||
new RMAppEvent(application.getApplicationId(), RMAppEventType.APP_NEW_SAVED);
|
new RMAppEvent(application.getApplicationId(),
|
||||||
|
RMAppEventType.APP_NEW_SAVED);
|
||||||
application.handle(event);
|
application.handle(event);
|
||||||
assertStartTimeSet(application);
|
assertStartTimeSet(application);
|
||||||
assertAppState(RMAppState.SUBMITTED, application);
|
assertAppState(RMAppState.SUBMITTED, application);
|
||||||
|
// verify sendATSCreateEvent() is get called during
|
||||||
|
// AddApplicationToSchedulerTransition.
|
||||||
|
verify(publisher).appCreated(eq(application), anyLong());
|
||||||
return application;
|
return application;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -402,7 +410,6 @@ public class TestRMAppTransitions {
|
||||||
RMAppEvent event =
|
RMAppEvent event =
|
||||||
new RMAppRecoverEvent(application.getApplicationId(), state);
|
new RMAppRecoverEvent(application.getApplicationId(), state);
|
||||||
|
|
||||||
|
|
||||||
application.handle(event);
|
application.handle(event);
|
||||||
assertStartTimeSet(application);
|
assertStartTimeSet(application);
|
||||||
assertAppState(RMAppState.SUBMITTED, application);
|
assertAppState(RMAppState.SUBMITTED, application);
|
||||||
|
@ -412,7 +419,7 @@ public class TestRMAppTransitions {
|
||||||
protected RMApp testCreateAppAccepted(
|
protected RMApp testCreateAppAccepted(
|
||||||
ApplicationSubmissionContext submissionContext) throws IOException {
|
ApplicationSubmissionContext submissionContext) throws IOException {
|
||||||
RMApp application = testCreateAppSubmittedNoRecovery(submissionContext);
|
RMApp application = testCreateAppSubmittedNoRecovery(submissionContext);
|
||||||
// SUBMITTED => ACCEPTED event RMAppEventType.APP_ACCEPTED
|
// SUBMITTED => ACCEPTED event RMAppEventType.APP_ACCEPTED
|
||||||
RMAppEvent event =
|
RMAppEvent event =
|
||||||
new RMAppEvent(application.getApplicationId(),
|
new RMAppEvent(application.getApplicationId(),
|
||||||
RMAppEventType.APP_ACCEPTED);
|
RMAppEventType.APP_ACCEPTED);
|
||||||
|
@ -424,7 +431,7 @@ public class TestRMAppTransitions {
|
||||||
|
|
||||||
protected RMApp testCreateAppRunning(
|
protected RMApp testCreateAppRunning(
|
||||||
ApplicationSubmissionContext submissionContext) throws IOException {
|
ApplicationSubmissionContext submissionContext) throws IOException {
|
||||||
RMApp application = testCreateAppAccepted(submissionContext);
|
RMApp application = testCreateAppAccepted(submissionContext);
|
||||||
// ACCEPTED => RUNNING event RMAppEventType.ATTEMPT_REGISTERED
|
// ACCEPTED => RUNNING event RMAppEventType.ATTEMPT_REGISTERED
|
||||||
RMAppEvent event =
|
RMAppEvent event =
|
||||||
new RMAppEvent(application.getApplicationId(),
|
new RMAppEvent(application.getApplicationId(),
|
||||||
|
|
Loading…
Reference in New Issue