YARN-8683. Support to display pending scheduling requests in RM app attempt page. Contributed by Tao Yang.
This commit is contained in:
parent
d3fef7a5c5
commit
54d0bf8935
|
@ -877,6 +877,16 @@ public abstract class AbstractYarnScheduler
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<SchedulingRequest> getPendingSchedulingRequestsForAttempt(
|
||||||
|
ApplicationAttemptId attemptId) {
|
||||||
|
SchedulerApplicationAttempt attempt = getApplicationAttempt(attemptId);
|
||||||
|
if (attempt != null) {
|
||||||
|
return attempt.getAppSchedulingInfo().getAllSchedulingRequests();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Priority checkAndGetApplicationPriority(
|
public Priority checkAndGetApplicationPriority(
|
||||||
Priority priorityRequestedByApp, UserGroupInformation user,
|
Priority priorityRequestedByApp, UserGroupInformation user,
|
||||||
|
|
|
@ -476,6 +476,23 @@ public class AppSchedulingInfo {
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fetch SchedulingRequests.
|
||||||
|
* @return All pending SchedulingRequests.
|
||||||
|
*/
|
||||||
|
public List<SchedulingRequest> getAllSchedulingRequests() {
|
||||||
|
List<SchedulingRequest> ret = new ArrayList<>();
|
||||||
|
try {
|
||||||
|
this.readLock.lock();
|
||||||
|
schedulerKeyToAppPlacementAllocator.values().stream()
|
||||||
|
.filter(ap -> ap.getSchedulingRequest() != null)
|
||||||
|
.forEach(ap -> ret.add(ap.getSchedulingRequest()));
|
||||||
|
} finally {
|
||||||
|
this.readLock.unlock();
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
public PendingAsk getNextPendingAsk() {
|
public PendingAsk getNextPendingAsk() {
|
||||||
try {
|
try {
|
||||||
readLock.lock();
|
readLock.lock();
|
||||||
|
|
|
@ -363,6 +363,16 @@ public interface YarnScheduler extends EventHandler<SchedulerEvent> {
|
||||||
List<ResourceRequest> getPendingResourceRequestsForAttempt(
|
List<ResourceRequest> getPendingResourceRequestsForAttempt(
|
||||||
ApplicationAttemptId attemptId);
|
ApplicationAttemptId attemptId);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get pending scheduling request for specified application attempt.
|
||||||
|
*
|
||||||
|
* @param attemptId the id of the application attempt
|
||||||
|
*
|
||||||
|
* @return pending scheduling requests
|
||||||
|
*/
|
||||||
|
List<SchedulingRequest> getPendingSchedulingRequestsForAttempt(
|
||||||
|
ApplicationAttemptId attemptId);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get cluster max priority.
|
* Get cluster max priority.
|
||||||
*
|
*
|
||||||
|
|
|
@ -192,4 +192,10 @@ public abstract class AppPlacementAllocator<N extends SchedulerNode> {
|
||||||
this.rmContext = rmContext;
|
this.rmContext = rmContext;
|
||||||
this.schedulerRequestKey = schedulerRequestKey;
|
this.schedulerRequestKey = schedulerRequestKey;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Get pending SchedulingRequest.
|
||||||
|
* @return SchedulingRequest
|
||||||
|
*/
|
||||||
|
public abstract SchedulingRequest getSchedulingRequest();
|
||||||
}
|
}
|
||||||
|
|
|
@ -425,4 +425,9 @@ public class LocalityAppPlacementAllocator <N extends SchedulerNode>
|
||||||
writeLock.unlock();
|
writeLock.unlock();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SchedulingRequest getSchedulingRequest() {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -505,8 +505,8 @@ public class SingleConstraintAppPlacementAllocator<N extends SchedulerNode>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@VisibleForTesting
|
@Override
|
||||||
SchedulingRequest getSchedulingRequest() {
|
public SchedulingRequest getSchedulingRequest() {
|
||||||
return schedulingRequest;
|
return schedulingRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -87,10 +87,14 @@ public class RMAppAttemptBlock extends AppAttemptBlock{
|
||||||
.h3("Total Outstanding Resource Requests: "
|
.h3("Total Outstanding Resource Requests: "
|
||||||
+ getTotalResource(resourceRequests))
|
+ getTotalResource(resourceRequests))
|
||||||
.table("#resourceRequests").thead().tr().th(".priority", "Priority")
|
.table("#resourceRequests").thead().tr().th(".priority", "Priority")
|
||||||
|
.th(".allocationRequestId", "AllocationRequestId")
|
||||||
.th(".resource", "ResourceName").th(".capacity", "Capability")
|
.th(".resource", "ResourceName").th(".capacity", "Capability")
|
||||||
.th(".containers", "NumContainers")
|
.th(".containers", "NumContainers")
|
||||||
.th(".relaxlocality", "RelaxLocality")
|
.th(".relaxlocality", "RelaxLocality")
|
||||||
.th(".labelexpression", "NodeLabelExpression").__().__().tbody();
|
.th(".labelexpression", "NodeLabelExpression")
|
||||||
|
.th(".executiontype", "ExecutionType")
|
||||||
|
.th(".allocationTags", "AllocationTags")
|
||||||
|
.th(".placementConstraint", "PlacementConstraint").__().__().tbody();
|
||||||
|
|
||||||
StringBuilder resourceRequestTableData = new StringBuilder("[\n");
|
StringBuilder resourceRequestTableData = new StringBuilder("[\n");
|
||||||
for (ResourceRequestInfo resourceRequest : resourceRequests) {
|
for (ResourceRequestInfo resourceRequest : resourceRequests) {
|
||||||
|
@ -99,7 +103,11 @@ public class RMAppAttemptBlock extends AppAttemptBlock{
|
||||||
}
|
}
|
||||||
resourceRequestTableData.append("[\"")
|
resourceRequestTableData.append("[\"")
|
||||||
.append(String.valueOf(resourceRequest.getPriority())).append("\",\"")
|
.append(String.valueOf(resourceRequest.getPriority())).append("\",\"")
|
||||||
.append(resourceRequest.getResourceName()).append("\",\"")
|
.append(String.valueOf(resourceRequest.getAllocationRequestId()))
|
||||||
|
.append("\",\"")
|
||||||
|
.append(resourceRequest.getResourceName() == null ? "N/A"
|
||||||
|
: resourceRequest.getResourceName())
|
||||||
|
.append("\",\"")
|
||||||
.append(StringEscapeUtils.escapeEcmaScript(StringEscapeUtils
|
.append(StringEscapeUtils.escapeEcmaScript(StringEscapeUtils
|
||||||
.escapeHtml4(String.valueOf(resourceRequest.getCapability()))))
|
.escapeHtml4(String.valueOf(resourceRequest.getCapability()))))
|
||||||
.append("\",\"")
|
.append("\",\"")
|
||||||
|
@ -109,6 +117,15 @@ public class RMAppAttemptBlock extends AppAttemptBlock{
|
||||||
.append("\",\"")
|
.append("\",\"")
|
||||||
.append(resourceRequest.getNodeLabelExpression() == null ? "N/A"
|
.append(resourceRequest.getNodeLabelExpression() == null ? "N/A"
|
||||||
: resourceRequest.getNodeLabelExpression())
|
: resourceRequest.getNodeLabelExpression())
|
||||||
|
.append("\",\"")
|
||||||
|
.append(resourceRequest.getExecutionTypeRequest() == null ? "N/A"
|
||||||
|
: resourceRequest.getExecutionTypeRequest().getExecutionType())
|
||||||
|
.append("\",\"")
|
||||||
|
.append(resourceRequest.getAllocationTags() == null ? "N/A" :
|
||||||
|
StringUtils.join(resourceRequest.getAllocationTags(), ","))
|
||||||
|
.append("\",\"")
|
||||||
|
.append(resourceRequest.getPlacementConstraint() == null ? "N/A"
|
||||||
|
: resourceRequest.getPlacementConstraint())
|
||||||
.append("\"],\n");
|
.append("\"],\n");
|
||||||
}
|
}
|
||||||
if (resourceRequestTableData
|
if (resourceRequestTableData
|
||||||
|
@ -132,7 +149,8 @@ public class RMAppAttemptBlock extends AppAttemptBlock{
|
||||||
if (request.getNumContainers() == 0) {
|
if (request.getNumContainers() == 0) {
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
if (request.getResourceName().equals(ResourceRequest.ANY)) {
|
if (request.getResourceName() == null || request.getResourceName()
|
||||||
|
.equals(ResourceRequest.ANY)) {
|
||||||
Resources.addTo(
|
Resources.addTo(
|
||||||
totalResource,
|
totalResource,
|
||||||
Resources.multiply(request.getCapability().getResource(),
|
Resources.multiply(request.getCapability().getResource(),
|
||||||
|
|
|
@ -36,6 +36,7 @@ import org.apache.hadoop.yarn.api.records.FinalApplicationStatus;
|
||||||
import org.apache.hadoop.yarn.api.records.LogAggregationStatus;
|
import org.apache.hadoop.yarn.api.records.LogAggregationStatus;
|
||||||
import org.apache.hadoop.yarn.api.records.Resource;
|
import org.apache.hadoop.yarn.api.records.Resource;
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceRequest;
|
import org.apache.hadoop.yarn.api.records.ResourceRequest;
|
||||||
|
import org.apache.hadoop.yarn.api.records.SchedulingRequest;
|
||||||
import org.apache.hadoop.yarn.api.records.YarnApplicationState;
|
import org.apache.hadoop.yarn.api.records.YarnApplicationState;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager;
|
import org.apache.hadoop.yarn.server.resourcemanager.ResourceManager;
|
||||||
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.RMApp;
|
import org.apache.hadoop.yarn.server.resourcemanager.rmapp.RMApp;
|
||||||
|
@ -230,6 +231,15 @@ public class AppInfo {
|
||||||
resourceRequests.add(new ResourceRequestInfo(req));
|
resourceRequests.add(new ResourceRequestInfo(req));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<SchedulingRequest> schedulingRequestsRaw = rm.getRMContext()
|
||||||
|
.getScheduler().getPendingSchedulingRequestsForAttempt(
|
||||||
|
attempt.getAppAttemptId());
|
||||||
|
if (schedulingRequestsRaw != null) {
|
||||||
|
for (SchedulingRequest req : schedulingRequestsRaw) {
|
||||||
|
resourceRequests.add(new ResourceRequestInfo(req));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,11 +21,13 @@ package org.apache.hadoop.yarn.server.resourcemanager.webapp.dao;
|
||||||
import org.apache.hadoop.yarn.api.records.ExecutionTypeRequest;
|
import org.apache.hadoop.yarn.api.records.ExecutionTypeRequest;
|
||||||
import org.apache.hadoop.yarn.api.records.Priority;
|
import org.apache.hadoop.yarn.api.records.Priority;
|
||||||
import org.apache.hadoop.yarn.api.records.ResourceRequest;
|
import org.apache.hadoop.yarn.api.records.ResourceRequest;
|
||||||
|
import org.apache.hadoop.yarn.api.records.SchedulingRequest;
|
||||||
|
|
||||||
import javax.xml.bind.annotation.XmlAccessType;
|
import javax.xml.bind.annotation.XmlAccessType;
|
||||||
import javax.xml.bind.annotation.XmlAccessorType;
|
import javax.xml.bind.annotation.XmlAccessorType;
|
||||||
import javax.xml.bind.annotation.XmlElement;
|
import javax.xml.bind.annotation.XmlElement;
|
||||||
import javax.xml.bind.annotation.XmlRootElement;
|
import javax.xml.bind.annotation.XmlRootElement;
|
||||||
|
import java.util.Set;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Simple class representing a resource request.
|
* Simple class representing a resource request.
|
||||||
|
@ -36,6 +38,8 @@ public class ResourceRequestInfo {
|
||||||
|
|
||||||
@XmlElement(name = "priority")
|
@XmlElement(name = "priority")
|
||||||
private int priority;
|
private int priority;
|
||||||
|
@XmlElement(name = "allocationRequestId")
|
||||||
|
private long allocationRequestId;
|
||||||
@XmlElement(name = "resourceName")
|
@XmlElement(name = "resourceName")
|
||||||
private String resourceName;
|
private String resourceName;
|
||||||
@XmlElement(name = "capability")
|
@XmlElement(name = "capability")
|
||||||
|
@ -50,16 +54,17 @@ public class ResourceRequestInfo {
|
||||||
@XmlElement(name = "executionTypeRequest")
|
@XmlElement(name = "executionTypeRequest")
|
||||||
private ExecutionTypeRequestInfo executionTypeRequest;
|
private ExecutionTypeRequestInfo executionTypeRequest;
|
||||||
|
|
||||||
@XmlElement(name = "executionType")
|
@XmlElement(name = "placementConstraint")
|
||||||
private String executionType;
|
private String placementConstraint;
|
||||||
@XmlElement(name = "enforceExecutionType")
|
@XmlElement(name = "allocationTags")
|
||||||
private boolean enforceExecutionType;
|
private Set<String> allocationTags;
|
||||||
|
|
||||||
public ResourceRequestInfo() {
|
public ResourceRequestInfo() {
|
||||||
}
|
}
|
||||||
|
|
||||||
public ResourceRequestInfo(ResourceRequest request) {
|
public ResourceRequestInfo(ResourceRequest request) {
|
||||||
priority = request.getPriority().getPriority();
|
priority = request.getPriority().getPriority();
|
||||||
|
allocationRequestId = request.getAllocationRequestId();
|
||||||
resourceName = request.getResourceName();
|
resourceName = request.getResourceName();
|
||||||
capability = new ResourceInfo(request.getCapability());
|
capability = new ResourceInfo(request.getCapability());
|
||||||
numContainers = request.getNumContainers();
|
numContainers = request.getNumContainers();
|
||||||
|
@ -71,6 +76,21 @@ public class ResourceRequestInfo {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ResourceRequestInfo(SchedulingRequest request) {
|
||||||
|
priority = request.getPriority().getPriority();
|
||||||
|
allocationRequestId = request.getAllocationRequestId();
|
||||||
|
capability = new ResourceInfo(request.getResourceSizing().getResources());
|
||||||
|
numContainers = request.getResourceSizing().getNumAllocations();
|
||||||
|
if (request.getExecutionType() != null) {
|
||||||
|
executionTypeRequest =
|
||||||
|
new ExecutionTypeRequestInfo(request.getExecutionType());
|
||||||
|
}
|
||||||
|
allocationTags = request.getAllocationTags();
|
||||||
|
if (request.getPlacementConstraint() != null) {
|
||||||
|
placementConstraint = request.getPlacementConstraint().toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public Priority getPriority() {
|
public Priority getPriority() {
|
||||||
return Priority.newInstance(priority);
|
return Priority.newInstance(priority);
|
||||||
}
|
}
|
||||||
|
@ -128,4 +148,28 @@ public class ResourceRequestInfo {
|
||||||
public ExecutionTypeRequestInfo getExecutionTypeRequest() {
|
public ExecutionTypeRequestInfo getExecutionTypeRequest() {
|
||||||
return executionTypeRequest;
|
return executionTypeRequest;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public String getPlacementConstraint() {
|
||||||
|
return placementConstraint;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPlacementConstraint(String placementConstraint) {
|
||||||
|
this.placementConstraint = placementConstraint;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Set<String> getAllocationTags() {
|
||||||
|
return allocationTags;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAllocationTags(Set<String> allocationTags) {
|
||||||
|
this.allocationTags = allocationTags;
|
||||||
|
}
|
||||||
|
|
||||||
|
public long getAllocationRequestId() {
|
||||||
|
return allocationRequestId;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setAllocationRequestId(long allocationRequestId) {
|
||||||
|
this.allocationRequestId = allocationRequestId;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue