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:
parent
61bc2c05af
commit
8d49c2fc3b
|
@ -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
|
||||||
|
|
Loading…
Reference in New Issue