YARN-3432. Cluster metrics have wrong Total Memory when there is reserved memory on CS. (Brahma Reddy Battula via curino)

(cherry picked from commit 892a8348fceb42069ea9877251c413fe33415e16)
This commit is contained in:
Carlo Curino 2016-10-27 15:12:10 -07:00 committed by Brahma Reddy Battula
parent 5aa26aa66e
commit 2de984ac3d
2 changed files with 12 additions and 2 deletions

View File

@ -53,6 +53,9 @@ Release 2.7.4 - UNRELEASED
YARN-5382. RM does not audit log kill request for active applications
(Vrushali C via jlowe)
YARN-3432. Cluster metrics have wrong Total Memory when there is reserved
memory on CS. (Brahma Reddy Battula via curino)
Release 2.7.3 - 2016-08-25
INCOMPATIBLE CHANGES

View File

@ -25,6 +25,7 @@
import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.QueueMetrics;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
@XmlRootElement(name = "clusterMetrics")
@XmlAccessorType(XmlAccessType.FIELD)
@ -85,8 +86,14 @@ public ClusterMetricsInfo(final ResourceManager rm) {
this.containersPending = metrics.getPendingContainers();
this.containersReserved = metrics.getReservedContainers();
this.totalMB = availableMB + allocatedMB;
this.totalVirtualCores = availableVirtualCores + allocatedVirtualCores;
if (rs instanceof CapacityScheduler) {
this.totalMB = availableMB + allocatedMB + reservedMB;
this.totalVirtualCores = availableVirtualCores + allocatedVirtualCores
+ containersReserved;
} else {
this.totalMB = availableMB + allocatedMB;
this.totalVirtualCores = availableVirtualCores + allocatedVirtualCores;
}
this.activeNodes = clusterMetrics.getNumActiveNMs();
this.lostNodes = clusterMetrics.getNumLostNMs();
this.unhealthyNodes = clusterMetrics.getUnhealthyNMs();