YARN-6428. Queue AM limit is not honored in CS always. Contributed by Bibin A Chundatt.

(cherry picked from commit 626d730bfc)
This commit is contained in:
Naganarasimha 2017-07-09 17:26:09 +05:30
parent fcef28e53b
commit b08ef44d9e
2 changed files with 47 additions and 15 deletions

View File

@ -210,27 +210,19 @@ public class DominantResourceCalculator extends ResourceCalculator {
public Resource multiplyAndNormalizeUp(Resource r, double by, public Resource multiplyAndNormalizeUp(Resource r, double by,
Resource stepFactor) { Resource stepFactor) {
return Resources.createResource( return Resources.createResource(
roundUp( roundUp((long) Math.ceil((float) (r.getMemorySize() * by)),
(int)Math.ceil(r.getMemorySize() * by), stepFactor.getMemorySize()), stepFactor.getMemorySize()),
roundUp( roundUp((int) Math.ceil((float) (r.getVirtualCores() * by)),
(int)Math.ceil(r.getVirtualCores() * by), stepFactor.getVirtualCores()));
stepFactor.getVirtualCores())
);
} }
@Override @Override
public Resource multiplyAndNormalizeDown(Resource r, double by, public Resource multiplyAndNormalizeDown(Resource r, double by,
Resource stepFactor) { Resource stepFactor) {
return Resources.createResource( return Resources.createResource(
roundDown( roundDown((long) (r.getMemorySize() * by), stepFactor.getMemorySize()),
(int)(r.getMemorySize() * by), roundDown((int) (r.getVirtualCores() * by),
stepFactor.getMemorySize() stepFactor.getVirtualCores()));
),
roundDown(
(int)(r.getVirtualCores() * by),
stepFactor.getVirtualCores()
)
);
} }
@Override @Override

View File

@ -4416,4 +4416,44 @@ public class TestCapacityScheduler {
Assert.assertEquals(b1.getState(), QueueState.RUNNING); Assert.assertEquals(b1.getState(), QueueState.RUNNING);
Assert.assertTrue(!b1.getChildQueues().isEmpty()); Assert.assertTrue(!b1.getChildQueues().isEmpty());
} }
@Test(timeout = 30000)
public void testAMLimitDouble() throws Exception {
CapacitySchedulerConfiguration config =
new CapacitySchedulerConfiguration();
config.set(CapacitySchedulerConfiguration.RESOURCE_CALCULATOR_CLASS,
DominantResourceCalculator.class.getName());
CapacitySchedulerConfiguration conf =
new CapacitySchedulerConfiguration(config);
conf.setClass(YarnConfiguration.RM_SCHEDULER, CapacityScheduler.class,
ResourceScheduler.class);
conf.setInt("yarn.scheduler.minimum-allocation-mb", 512);
conf.setInt("yarn.scheduler.minimum-allocation-vcores", 1);
MockRM rm = new MockRM(conf);
rm.start();
rm.registerNode("127.0.0.1:1234", 10 * GB);
rm.registerNode("127.0.0.1:1235", 10 * GB);
rm.registerNode("127.0.0.1:1236", 10 * GB);
rm.registerNode("127.0.0.1:1237", 10 * GB);
ResourceScheduler scheduler = rm.getRMContext().getScheduler();
waitforNMRegistered(scheduler, 4, 5);
LeafQueue queueA =
(LeafQueue) ((CapacityScheduler) scheduler).getQueue("default");
Resource amResourceLimit = queueA.getAMResourceLimit();
Assert.assertEquals(4096, amResourceLimit.getMemorySize());
Assert.assertEquals(4, amResourceLimit.getVirtualCores());
rm.stop();
}
private void waitforNMRegistered(ResourceScheduler scheduler, int nodecount,
int timesec) throws InterruptedException {
long start = System.currentTimeMillis();
while (System.currentTimeMillis() - start < timesec * 1000) {
if (scheduler.getNumClusterNodes() < nodecount) {
Thread.sleep(100);
} else {
break;
}
}
}
} }