YARN-7489. ConcurrentModificationException in RMAppImpl#getRMAppMetrics. Contributed by Tao Yang.
(cherry picked from commit 5c2986e58d
)
This commit is contained in:
parent
ee267565b5
commit
dc4132395e
|
@ -1616,24 +1616,29 @@ public class RMAppImpl implements RMApp, Recoverable {
|
||||||
long vcoreSeconds = 0;
|
long vcoreSeconds = 0;
|
||||||
long preemptedMemorySeconds = 0;
|
long preemptedMemorySeconds = 0;
|
||||||
long preemptedVcoreSeconds = 0;
|
long preemptedVcoreSeconds = 0;
|
||||||
for (RMAppAttempt attempt : attempts.values()) {
|
this.readLock.lock();
|
||||||
if (null != attempt) {
|
try {
|
||||||
RMAppAttemptMetrics attemptMetrics =
|
for (RMAppAttempt attempt : attempts.values()) {
|
||||||
attempt.getRMAppAttemptMetrics();
|
if (null != attempt) {
|
||||||
Resources.addTo(resourcePreempted,
|
RMAppAttemptMetrics attemptMetrics =
|
||||||
attemptMetrics.getResourcePreempted());
|
attempt.getRMAppAttemptMetrics();
|
||||||
numAMContainerPreempted += attemptMetrics.getIsPreempted() ? 1 : 0;
|
Resources.addTo(resourcePreempted,
|
||||||
numNonAMContainerPreempted +=
|
attemptMetrics.getResourcePreempted());
|
||||||
attemptMetrics.getNumNonAMContainersPreempted();
|
numAMContainerPreempted += attemptMetrics.getIsPreempted() ? 1 : 0;
|
||||||
// getAggregateAppResourceUsage() will calculate resource usage stats
|
numNonAMContainerPreempted +=
|
||||||
// for both running and finished containers.
|
attemptMetrics.getNumNonAMContainersPreempted();
|
||||||
AggregateAppResourceUsage resUsage =
|
// getAggregateAppResourceUsage() will calculate resource usage stats
|
||||||
attempt.getRMAppAttemptMetrics().getAggregateAppResourceUsage();
|
// for both running and finished containers.
|
||||||
memorySeconds += resUsage.getMemorySeconds();
|
AggregateAppResourceUsage resUsage =
|
||||||
vcoreSeconds += resUsage.getVcoreSeconds();
|
attempt.getRMAppAttemptMetrics().getAggregateAppResourceUsage();
|
||||||
preemptedMemorySeconds += attemptMetrics.getPreemptedMemory();
|
memorySeconds += resUsage.getMemorySeconds();
|
||||||
preemptedVcoreSeconds += attemptMetrics.getPreemptedVcore();
|
vcoreSeconds += resUsage.getVcoreSeconds();
|
||||||
|
preemptedMemorySeconds += attemptMetrics.getPreemptedMemory();
|
||||||
|
preemptedVcoreSeconds += attemptMetrics.getPreemptedVcore();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
} finally {
|
||||||
|
this.readLock.unlock();
|
||||||
}
|
}
|
||||||
|
|
||||||
return new RMAppMetrics(resourcePreempted,
|
return new RMAppMetrics(resourcePreempted,
|
||||||
|
|
Loading…
Reference in New Issue