YARN-10912. AbstractCSQueue#updateConfigurableResourceRequirement: Separate validation logic from initialization logic (#3390)
- capacityConfigType update is extracted to a separate method - validation logic is extracted to a helper function - min resource must not be greater than max resource is now checked after the max resource is updated Change-Id: I731c2639281721afed32c30854bafcf048d6ee28 Co-authored-by: Tamas Domok <tdomok@cloudera.com>
This commit is contained in:
parent
4f563ff1ba
commit
63c892278f
|
@ -369,14 +369,15 @@ public abstract class AbstractCSQueue implements CSQueue {
|
||||||
setupConfigurableCapacities(configuration);
|
setupConfigurableCapacities(configuration);
|
||||||
updateAbsoluteCapacities();
|
updateAbsoluteCapacities();
|
||||||
|
|
||||||
|
updateCapacityConfigType();
|
||||||
|
|
||||||
// Fetch minimum/maximum resource limits for this queue if
|
// Fetch minimum/maximum resource limits for this queue if
|
||||||
// configured
|
// configured
|
||||||
capacityConfigType = CapacityConfigType.NONE;
|
|
||||||
this.resourceTypes = new HashSet<>();
|
this.resourceTypes = new HashSet<>();
|
||||||
for (AbsoluteResourceType type : AbsoluteResourceType.values()) {
|
for (AbsoluteResourceType type : AbsoluteResourceType.values()) {
|
||||||
resourceTypes.add(type.toString().toLowerCase());
|
resourceTypes.add(type.toString().toLowerCase());
|
||||||
}
|
}
|
||||||
updateConfigurableResourceRequirement(getQueuePath(), clusterResource);
|
updateConfigurableResourceLimits(clusterResource);
|
||||||
|
|
||||||
// Setup queue's maximumAllocation respecting the global
|
// Setup queue's maximumAllocation respecting the global
|
||||||
// and the queue settings
|
// and the queue settings
|
||||||
|
@ -601,12 +602,9 @@ public abstract class AbstractCSQueue implements CSQueue {
|
||||||
queuePath, resourceTypes);
|
queuePath, resourceTypes);
|
||||||
}
|
}
|
||||||
|
|
||||||
protected void updateConfigurableResourceRequirement(String queuePath,
|
protected void updateCapacityConfigType() {
|
||||||
Resource clusterResource) {
|
this.capacityConfigType = CapacityConfigType.NONE;
|
||||||
for (String label : configuredNodeLabels) {
|
for (String label : configuredNodeLabels) {
|
||||||
Resource minResource = getMinimumAbsoluteResource(queuePath, label);
|
|
||||||
Resource maxResource = getMaximumAbsoluteResource(queuePath, label);
|
|
||||||
|
|
||||||
LOG.debug("capacityConfigType is '{}' for queue {}",
|
LOG.debug("capacityConfigType is '{}' for queue {}",
|
||||||
capacityConfigType, getQueuePath());
|
capacityConfigType, getQueuePath());
|
||||||
|
|
||||||
|
@ -621,39 +619,35 @@ public abstract class AbstractCSQueue implements CSQueue {
|
||||||
} else {
|
} else {
|
||||||
validateAbsoluteVsPercentageCapacityConfig(localType);
|
validateAbsoluteVsPercentageCapacityConfig(localType);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
// If min resource for a resource type is greater than its max resource,
|
|
||||||
// throw exception to handle such error configs.
|
|
||||||
if (!maxResource.equals(Resources.none()) && Resources.greaterThan(
|
|
||||||
resourceCalculator, clusterResource, minResource, maxResource)) {
|
|
||||||
throw new IllegalArgumentException("Min resource configuration "
|
|
||||||
+ minResource + " is greater than its max value:" + maxResource
|
|
||||||
+ " in queue:" + getQueuePath());
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// If parent's max resource is lesser to a specific child's max
|
protected void updateConfigurableResourceLimits(Resource clusterResource) {
|
||||||
// resource, throw exception to handle such error configs.
|
for (String label : configuredNodeLabels) {
|
||||||
|
final Resource minResource = getMinimumAbsoluteResource(queuePath, label);
|
||||||
|
Resource maxResource = getMaximumAbsoluteResource(queuePath, label);
|
||||||
|
|
||||||
if (parent != null) {
|
if (parent != null) {
|
||||||
Resource parentMaxRes = parent.getQueueResourceQuotas()
|
final Resource parentMax = parent.getQueueResourceQuotas().getConfiguredMaxResource(label);
|
||||||
.getConfiguredMaxResource(label);
|
validateMinResourceIsNotGreaterThanMaxResource(maxResource, parentMax, clusterResource,
|
||||||
if (Resources.greaterThan(resourceCalculator, clusterResource,
|
"Max resource configuration "
|
||||||
parentMaxRes, Resources.none())) {
|
|
||||||
if (Resources.greaterThan(resourceCalculator, clusterResource,
|
|
||||||
maxResource, parentMaxRes)) {
|
|
||||||
throw new IllegalArgumentException("Max resource configuration "
|
|
||||||
+ maxResource + " is greater than parents max value:"
|
+ maxResource + " is greater than parents max value:"
|
||||||
+ parentMaxRes + " in queue:" + getQueuePath());
|
+ parentMax + " in queue:" + getQueuePath());
|
||||||
}
|
|
||||||
|
|
||||||
// If child's max resource is not set, but its parent max resource is
|
// If child's max resource is not set, but its parent max resource is
|
||||||
// set, we must set child max resource to its parent's.
|
// set, we must set child max resource to its parent's.
|
||||||
if (maxResource.equals(Resources.none())
|
if (maxResource.equals(Resources.none()) &&
|
||||||
&& !minResource.equals(Resources.none())) {
|
!minResource.equals(Resources.none()) &&
|
||||||
maxResource = Resources.clone(parentMaxRes);
|
!parentMax.equals(Resources.none())) {
|
||||||
}
|
maxResource = Resources.clone(parentMax);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
validateMinResourceIsNotGreaterThanMaxResource(minResource, maxResource, clusterResource,
|
||||||
|
"Min resource configuration "
|
||||||
|
+ minResource + " is greater than its max value:" + maxResource
|
||||||
|
+ " in queue:" + getQueuePath());
|
||||||
|
|
||||||
LOG.debug("Updating absolute resource configuration for queue:{} as"
|
LOG.debug("Updating absolute resource configuration for queue:{} as"
|
||||||
+ " minResource={} and maxResource={}", getQueuePath(), minResource,
|
+ " minResource={} and maxResource={}", getQueuePath(), minResource,
|
||||||
maxResource);
|
maxResource);
|
||||||
|
@ -663,6 +657,16 @@ public abstract class AbstractCSQueue implements CSQueue {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void validateMinResourceIsNotGreaterThanMaxResource(Resource minResource,
|
||||||
|
Resource maxResource,
|
||||||
|
Resource clusterResource,
|
||||||
|
String validationError) {
|
||||||
|
if (!maxResource.equals(Resources.none()) && Resources.greaterThan(
|
||||||
|
resourceCalculator, clusterResource, minResource, maxResource)) {
|
||||||
|
throw new IllegalArgumentException(validationError);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void validateAbsoluteVsPercentageCapacityConfig(
|
private void validateAbsoluteVsPercentageCapacityConfig(
|
||||||
CapacityConfigType localType) {
|
CapacityConfigType localType) {
|
||||||
if (!queuePath.equals("root")
|
if (!queuePath.equals("root")
|
||||||
|
|
Loading…
Reference in New Issue