YARN-9756: Create metric that sums total memory/vcores preempted per round. Contributed by Manikandan R (manirajv06).

This commit is contained in:
Eric E Payne 2019-08-28 20:40:34 +00:00
parent 3e6a0166f4
commit 6f2226a013
4 changed files with 46 additions and 0 deletions

View File

@ -77,6 +77,10 @@ public class QueueMetrics implements MetricsSource {
@Metric("# of active applications") MutableGaugeInt activeApplications;
@Metric("App Attempt First Container Allocation Delay")
MutableRate appAttemptFirstContainerAllocationDelay;
@Metric("Aggregate total of preempted memory MB")
MutableCounterLong aggregateMemoryMBPreempted;
@Metric("Aggregate total of preempted vcores")
MutableCounterLong aggregateVcoresPreempted;
//Metrics updated only for "default" partition
@Metric("Allocated memory in MB") MutableGaugeLong allocatedMB;
@ -586,6 +590,23 @@ public class QueueMetrics implements MetricsSource {
}
}
public void updatePreemptedResources(Resource res) {
aggregateMemoryMBPreempted.incr(res.getMemorySize());
aggregateVcoresPreempted.incr(res.getVirtualCores());
if (parent != null) {
parent.updatePreemptedResources(res);
}
}
public void updatePreemptedForCustomResources(Resource res) {
if (queueMetricsForCustomResources != null) {
queueMetricsForCustomResources.increaseAggregatedPreempted(res);
}
if (parent != null) {
parent.updatePreemptedForCustomResources(res);
}
}
public void updatePreemptedSecondsForCustomResources(Resource res,
long seconds) {
if (queueMetricsForCustomResources != null) {
@ -753,6 +774,16 @@ public class QueueMetrics implements MetricsSource {
return aggregateVcoreSecondsPreempted;
}
@VisibleForTesting
public long getAggregateMemoryMBPreempted() {
return aggregateMemoryMBPreempted.value();
}
@VisibleForTesting
public long getAggregateVcoresPreempted() {
return aggregateVcoresPreempted.value();
}
public long getAllocatedMB() {
return allocatedMB.value();
}

View File

@ -28,6 +28,8 @@ import java.util.Map;
public class QueueMetricsForCustomResources {
private final QueueMetricsCustomResource aggregatePreemptedSeconds =
new QueueMetricsCustomResource();
private final QueueMetricsCustomResource aggregatePreempted =
new QueueMetricsCustomResource();
private final QueueMetricsCustomResource allocated =
new QueueMetricsCustomResource();
private final QueueMetricsCustomResource available =
@ -82,6 +84,10 @@ public class QueueMetricsForCustomResources {
aggregatePreemptedSeconds.increaseWithMultiplier(res, seconds);
}
public void increaseAggregatedPreempted(Resource res) {
aggregatePreempted.increase(res);
}
Map<String, Long> getAllocatedValues() {
return allocated.getValues();
}

View File

@ -2222,7 +2222,9 @@ public class LeafQueue extends AbstractCSQueue {
/ DateUtils.MILLIS_PER_SECOND;
metrics.updatePreemptedMemoryMBSeconds(mbSeconds);
metrics.updatePreemptedVcoreSeconds(vcSeconds);
metrics.updatePreemptedResources(containerResource);
metrics.updatePreemptedSecondsForCustomResources(containerResource,
usedSeconds);
metrics.updatePreemptedForCustomResources(containerResource);
}
}

View File

@ -185,6 +185,13 @@ public class TestCapacitySchedulerSurgicalPreemption
Assert.assertEquals("Number of preempted containers incorrectly recorded:",
4, cs.getQueue("root").getMetrics().getAggregatePreemptedContainers());
Assert.assertEquals("Amount of preempted memory incorrectly recorded:",
4 * GB,
cs.getQueue("root").getMetrics().getAggregateMemoryMBPreempted());
Assert.assertEquals("Number of preempted vcores incorrectly recorded:", 4,
cs.getQueue("root").getMetrics().getAggregateVcoresPreempted());
rm1.close();
}