YARN-7057. FSAppAttempt#getResourceUsage doesn't need to consider resources queued for preemption. (Contributed by Karthik via Yufei Gu)

(cherry picked from commit 82c5dd1d50)
This commit is contained in:
Yufei Gu 2017-09-12 14:58:23 -07:00
parent 61bc2c05af
commit 8d49c2fc3b
1 changed files with 10 additions and 9 deletions

View File

@ -614,9 +614,16 @@ public class FSAppAttempt extends SchedulerApplicationAttempt
// Check if the app's allocation will be over its fairshare even // Check if the app's allocation will be over its fairshare even
// after preempting this container // after preempting this container
Resource usageAfterPreemption = Resources.subtract( Resource usageAfterPreemption = Resources.clone(getResourceUsage());
getResourceUsage(), container.getAllocatedResource());
// Subtract resources of containers already queued for preemption
synchronized (preemptionVariablesLock) {
Resources.subtractFrom(usageAfterPreemption, resourcesToBePreempted);
}
// Subtract this container's allocation to compute usage after preemption
Resources.subtractFrom(
usageAfterPreemption, container.getAllocatedResource());
return !isUsageBelowShare(usageAfterPreemption, getFairShare()); return !isUsageBelowShare(usageAfterPreemption, getFairShare());
} }
@ -1270,13 +1277,7 @@ public class FSAppAttempt extends SchedulerApplicationAttempt
@Override @Override
public Resource getResourceUsage() { public Resource getResourceUsage() {
// Subtract copies the object, so that we have a snapshot, return getCurrentConsumption();
// in case usage changes, while the caller is using the value
synchronized (preemptionVariablesLock) {
return containersToBePreempted.isEmpty()
? getCurrentConsumption()
: Resources.subtract(getCurrentConsumption(), resourcesToBePreempted);
}
} }
@Override @Override