YARN-9810. Add queue capacity/maxcapacity percentage metrics. Contributed by Shubham Gupta
(cherry picked from commit0ccf4b0fe1
) (cherry picked from commit cb806988d72bde1f9837c9e0fb82a3a6c032542c) (cherry picked from commit37d1f8c81e
)
This commit is contained in:
parent
ad250a8cbb
commit
6e02d8fcfb
|
@ -55,6 +55,14 @@ public class CSQueueMetrics extends QueueMetrics {
|
|||
MutableGaugeLong maxCapacityMB;
|
||||
@Metric("Maximum CPU in virtual cores")
|
||||
MutableGaugeInt maxCapacityVCores;
|
||||
@Metric("Guaranteed capacity in percentage relative to parent")
|
||||
private MutableGaugeFloat guaranteedCapacity;
|
||||
@Metric("Guaranteed capacity in percentage relative to total partition")
|
||||
private MutableGaugeFloat guaranteedAbsoluteCapacity;
|
||||
@Metric("Maximum capacity in percentage relative to parent")
|
||||
private MutableGaugeFloat maxCapacity;
|
||||
@Metric("Maximum capacity in percentage relative to total partition")
|
||||
private MutableGaugeFloat maxAbsoluteCapacity;
|
||||
|
||||
CSQueueMetrics(MetricsSystem ms, String queueName, Queue parent,
|
||||
boolean enableUserMetrics, Configuration conf) {
|
||||
|
@ -204,4 +212,35 @@ public class CSQueueMetrics extends QueueMetrics {
|
|||
return metrics;
|
||||
}
|
||||
|
||||
public float getGuaranteedCapacity() {
|
||||
return guaranteedCapacity.value();
|
||||
}
|
||||
|
||||
public float getGuaranteedAbsoluteCapacity() {
|
||||
return guaranteedAbsoluteCapacity.value();
|
||||
}
|
||||
|
||||
public void setGuaranteedCapacities(String partition, float capacity,
|
||||
float absoluteCapacity) {
|
||||
if (partition == null || partition.equals(RMNodeLabelsManager.NO_LABEL)) {
|
||||
guaranteedCapacity.set(capacity);
|
||||
guaranteedAbsoluteCapacity.set(absoluteCapacity);
|
||||
}
|
||||
}
|
||||
|
||||
public float getMaxCapacity() {
|
||||
return maxCapacity.value();
|
||||
}
|
||||
|
||||
public float getMaxAbsoluteCapacity() {
|
||||
return maxAbsoluteCapacity.value();
|
||||
}
|
||||
|
||||
public void setMaxCapacities(String partition, float capacity,
|
||||
float absoluteCapacity) {
|
||||
if (partition == null || partition.equals(RMNodeLabelsManager.NO_LABEL)) {
|
||||
maxCapacity.set(capacity);
|
||||
maxAbsoluteCapacity.set(absoluteCapacity);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -316,5 +316,11 @@ class CSQueueUtils {
|
|||
queue.getMetrics().setMaxCapacityResources(partition, rc.multiplyAndNormalizeDown(
|
||||
partitionResource, queue.getQueueCapacities().getAbsoluteMaximumCapacity(partition),
|
||||
queue.getMinimumAllocation()));
|
||||
queue.getMetrics().setGuaranteedCapacities(partition,
|
||||
queue.getQueueCapacities().getCapacity(partition),
|
||||
queue.getQueueCapacities().getAbsoluteCapacity(partition));
|
||||
queue.getMetrics().setMaxCapacities(partition,
|
||||
queue.getQueueCapacities().getMaximumCapacity(partition),
|
||||
queue.getQueueCapacities().getAbsoluteMaximumCapacity(partition));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -204,6 +204,8 @@ public class TestCapacityScheduler {
|
|||
private ResourceManager resourceManager = null;
|
||||
private RMContext mockContext;
|
||||
|
||||
private static final double DELTA = 0.000001;
|
||||
|
||||
@Before
|
||||
public void setUp() throws Exception {
|
||||
resourceManager = new ResourceManager() {
|
||||
|
@ -5100,6 +5102,22 @@ public class TestCapacityScheduler {
|
|||
assertEquals(35840, ((CSQueueMetrics)cs.getQueue("b1").getMetrics()).getGuaranteedMB());
|
||||
assertEquals(51200, ((CSQueueMetrics)cs.getQueue("a").getMetrics()).getMaxCapacityMB());
|
||||
assertEquals(51200, ((CSQueueMetrics)cs.getQueue("b1").getMetrics()).getMaxCapacityMB());
|
||||
assertEquals(A_CAPACITY / 100, ((CSQueueMetrics)cs.getQueue("a")
|
||||
.getMetrics()).getGuaranteedCapacity(), DELTA);
|
||||
assertEquals(A_CAPACITY / 100, ((CSQueueMetrics)cs.getQueue("a")
|
||||
.getMetrics()).getGuaranteedAbsoluteCapacity(), DELTA);
|
||||
assertEquals(B1_CAPACITY / 100, ((CSQueueMetrics)cs.getQueue("b1")
|
||||
.getMetrics()).getGuaranteedCapacity(), DELTA);
|
||||
assertEquals((B_CAPACITY / 100) * (B1_CAPACITY / 100), ((CSQueueMetrics)cs
|
||||
.getQueue("b1").getMetrics()).getGuaranteedAbsoluteCapacity(), DELTA);
|
||||
assertEquals(1, ((CSQueueMetrics)cs.getQueue("a").getMetrics())
|
||||
.getMaxCapacity(), DELTA);
|
||||
assertEquals(1, ((CSQueueMetrics)cs.getQueue("a").getMetrics())
|
||||
.getMaxAbsoluteCapacity(), DELTA);
|
||||
assertEquals(1, ((CSQueueMetrics)cs.getQueue("b1").getMetrics())
|
||||
.getMaxCapacity(), DELTA);
|
||||
assertEquals(1, ((CSQueueMetrics)cs.getQueue("b1").getMetrics())
|
||||
.getMaxAbsoluteCapacity(), DELTA);
|
||||
|
||||
// Add child queue to a, and reinitialize. Metrics should be updated
|
||||
conf.setQueues(CapacitySchedulerConfiguration.ROOT + ".a", new String[] {"a1", "a2", "a3"} );
|
||||
|
|
Loading…
Reference in New Issue