YARN-11408. Add a check of autoQueueCreation is disabled for emitDefaultUserLimitFactor method (#5278)
* added a check of autoQueueCreationV2Disabled Change-Id: If1e36c5969d270c1b81a4bbd2e883fa819c81f20 * added check of AutoCreateChildQueueDisabled Change-Id: Ia011b4393ccd8d4d419a2e46b06a5237d050851c * removed auto-create-child-queue-enabled check and emit Change-Id: I7a154124519ecbd81379b46a238707c16db1e82a
This commit is contained in:
parent
fe5bb49ad9
commit
49b8ac19f2
@ -16,6 +16,8 @@
|
||||
|
||||
package org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.converter;
|
||||
|
||||
import static org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration.AUTO_QUEUE_CREATION_V2_ENABLED;
|
||||
import static org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration.DEFAULT_AUTO_QUEUE_CREATION_ENABLED;
|
||||
import static org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration.PREFIX;
|
||||
import static org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration.DOT;
|
||||
import static org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration.USER_LIMIT_FACTOR;
|
||||
@ -82,13 +84,13 @@ public void convertQueueHierarchy(FSQueue queue) {
|
||||
emitMaxParallelApps(queueName, queue);
|
||||
emitMaxAllocations(queueName, queue);
|
||||
emitPreemptionDisabled(queueName, queue);
|
||||
emitDefaultUserLimitFactor(queueName, children);
|
||||
|
||||
emitChildCapacity(queue);
|
||||
emitMaximumCapacity(queueName, queue);
|
||||
emitSizeBasedWeight(queueName);
|
||||
emitOrderingPolicy(queueName, queue);
|
||||
checkMaxChildCapacitySetting(queue);
|
||||
emitDefaultUserLimitFactor(queueName, children);
|
||||
|
||||
for (FSQueue childQueue : children) {
|
||||
convertQueueHierarchy(childQueue);
|
||||
@ -220,7 +222,7 @@ private void emitPreemptionDisabled(String queueName, FSQueue queue) {
|
||||
}
|
||||
|
||||
public void emitDefaultUserLimitFactor(String queueName, List<FSQueue> children) {
|
||||
if (children.isEmpty()) {
|
||||
if (children.isEmpty() && checkAutoQueueCreationV2Disabled(queueName)) {
|
||||
capacitySchedulerConfig.setFloat(
|
||||
CapacitySchedulerConfiguration.
|
||||
PREFIX + queueName + DOT + USER_LIMIT_FACTOR,
|
||||
@ -309,6 +311,12 @@ private void checkMaxChildCapacitySetting(FSQueue queue) {
|
||||
}
|
||||
}
|
||||
|
||||
private boolean checkAutoQueueCreationV2Disabled(String queueName) {
|
||||
return !capacitySchedulerConfig.getBoolean(
|
||||
PREFIX + queueName + DOT + AUTO_QUEUE_CREATION_V2_ENABLED,
|
||||
DEFAULT_AUTO_QUEUE_CREATION_ENABLED);
|
||||
}
|
||||
|
||||
private String getQueueShortName(String queueName) {
|
||||
int lastDot = queueName.lastIndexOf(".");
|
||||
return queueName.substring(lastDot + 1);
|
||||
|
@ -194,6 +194,8 @@ public void testDefaultUserLimitFactor() throws Exception {
|
||||
|
||||
assertNull("root.users user-limit-factor should be null",
|
||||
conf.get(PREFIX + "root.users." + USER_LIMIT_FACTOR));
|
||||
assertEquals("root.users auto-queue-creation-v2.enabled", "true",
|
||||
conf.get(PREFIX + "root.users.auto-queue-creation-v2.enabled"));
|
||||
|
||||
assertEquals("root.default user-limit-factor", "-1.0",
|
||||
conf.get(PREFIX + "root.default.user-limit-factor"));
|
||||
@ -203,6 +205,8 @@ public void testDefaultUserLimitFactor() throws Exception {
|
||||
|
||||
assertEquals("root.admins.bob user-limit-factor", "-1.0",
|
||||
conf.get(PREFIX + "root.admins.bob.user-limit-factor"));
|
||||
assertNull("root.admin.bob auto-queue-creation-v2.enabled should be null",
|
||||
conf.get(PREFIX + "root.admin.bob.auto-queue-creation-v2.enabled"));
|
||||
}
|
||||
|
||||
@Test
|
||||
|
Loading…
Reference in New Issue
Block a user