YARN-6751. Display reserved resources in web UI per queue
(Contributed by Abdullah Yousufi via Daniel Templeton)
(cherry picked from commit ec97519779
)
This commit is contained in:
parent
367f525e81
commit
93c5421a43
|
@ -57,6 +57,7 @@ public abstract class FSQueue implements Queue, Schedulable {
|
|||
|
||||
private Resource fairShare = Resources.createResource(0, 0);
|
||||
private Resource steadyFairShare = Resources.createResource(0, 0);
|
||||
private Resource reservedResource = Resources.createResource(0, 0);
|
||||
private final String name;
|
||||
protected final FairScheduler scheduler;
|
||||
private final YarnAuthorizationProvider authorizer;
|
||||
|
@ -161,6 +162,12 @@ public abstract class FSQueue implements Queue, Schedulable {
|
|||
this.maxShare = maxShare;
|
||||
}
|
||||
|
||||
public Resource getReservedResource() {
|
||||
reservedResource.setMemorySize(metrics.getReservedMB());
|
||||
reservedResource.setVirtualCores(metrics.getReservedVirtualCores());
|
||||
return reservedResource;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Resource getMaxShare() {
|
||||
return maxShare;
|
||||
|
|
|
@ -75,7 +75,8 @@ public class FairSchedulerPage extends RmView {
|
|||
_("Num Active Applications:", qinfo.getNumActiveApplications()).
|
||||
_("Num Pending Applications:", qinfo.getNumPendingApplications()).
|
||||
_("Min Resources:", qinfo.getMinResources().toString()).
|
||||
_("Max Resources:", qinfo.getMaxResources().toString());
|
||||
_("Max Resources:", qinfo.getMaxResources().toString()).
|
||||
_("Reserved Resources:", qinfo.getReservedResources().toString());
|
||||
int maxApps = qinfo.getMaxApplications();
|
||||
if (maxApps < Integer.MAX_VALUE) {
|
||||
ri._("Max Running Applications:", qinfo.getMaxApplications());
|
||||
|
@ -103,7 +104,8 @@ public class FairSchedulerPage extends RmView {
|
|||
ResponseInfo ri = info("\'" + qinfo.getQueueName() + "\' Queue Status").
|
||||
_("Used Resources:", qinfo.getUsedResources().toString()).
|
||||
_("Min Resources:", qinfo.getMinResources().toString()).
|
||||
_("Max Resources:", qinfo.getMaxResources().toString());
|
||||
_("Max Resources:", qinfo.getMaxResources().toString()).
|
||||
_("Reserved Resources:", qinfo.getReservedResources().toString());
|
||||
int maxApps = qinfo.getMaxApplications();
|
||||
if (maxApps < Integer.MAX_VALUE) {
|
||||
ri._("Max Running Applications:", qinfo.getMaxApplications());
|
||||
|
|
|
@ -58,6 +58,7 @@ public class FairSchedulerQueueInfo {
|
|||
private ResourceInfo steadyFairResources;
|
||||
private ResourceInfo fairResources;
|
||||
private ResourceInfo clusterResources;
|
||||
private ResourceInfo reservedResources;
|
||||
|
||||
private long pendingContainers;
|
||||
private long allocatedContainers;
|
||||
|
@ -93,6 +94,7 @@ public class FairSchedulerQueueInfo {
|
|||
maxResources = new ResourceInfo(
|
||||
Resources.componentwiseMin(queue.getMaxShare(),
|
||||
scheduler.getClusterResource()));
|
||||
reservedResources = new ResourceInfo(queue.getReservedResource());
|
||||
|
||||
fractionMemSteadyFairShare =
|
||||
(float)steadyFairResources.getMemorySize() / clusterResources.getMemorySize();
|
||||
|
@ -186,6 +188,10 @@ public class FairSchedulerQueueInfo {
|
|||
return maxResources;
|
||||
}
|
||||
|
||||
public ResourceInfo getReservedResources() {
|
||||
return reservedResources;
|
||||
}
|
||||
|
||||
public int getMaxApplications() {
|
||||
return maxApps;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue