YARN-5055. max apps per user can be larger than max per queue. Contributed by Eric Badger

(cherry picked from commit ac954486c5)
This commit is contained in:
Jason Lowe 2016-05-23 15:57:54 +00:00
parent 0abb366364
commit 27aeab63c7
4 changed files with 13 additions and 8 deletions

View File

@ -139,6 +139,9 @@ Release 2.7.3 - UNRELEASED
YARN-4747. AHS error 500 due to NPE when container start event is missing YARN-4747. AHS error 500 due to NPE when container start event is missing
(Varun Saxena via jlowe) (Varun Saxena via jlowe)
YARN-5055. max apps per user can be larger than max per queue (Eric Badger
via jlowe)
Release 2.7.2 - 2016-01-25 Release 2.7.2 - 2016-01-25
INCOMPATIBLE CHANGES INCOMPATIBLE CHANGES

View File

@ -170,8 +170,8 @@ public class LeafQueue extends AbstractCSQueue {
maxApplications = maxApplications =
(int) (maxSystemApps * queueCapacities.getAbsoluteCapacity()); (int) (maxSystemApps * queueCapacities.getAbsoluteCapacity());
} }
maxApplicationsPerUser = maxApplicationsPerUser = Math.min(maxApplications,
(int)(maxApplications * (userLimit / 100.0f) * userLimitFactor); (int)(maxApplications * (userLimit / 100.0f) * userLimitFactor));
maxAMResourcePerQueuePercent = maxAMResourcePerQueuePercent =
conf.getMaximumApplicationMasterResourcePerQueuePercent(getQueuePath()); conf.getMaximumApplicationMasterResourcePerQueuePercent(getQueuePath());

View File

@ -310,8 +310,9 @@ public class TestApplicationLimits {
queue.getAbsoluteCapacity()); queue.getAbsoluteCapacity());
assertEquals(expectedMaxApps, queue.getMaxApplications()); assertEquals(expectedMaxApps, queue.getMaxApplications());
int expectedMaxAppsPerUser = (int)(expectedMaxApps * int expectedMaxAppsPerUser = Math.min(expectedMaxApps,
(queue.getUserLimit()/100.0f) * queue.getUserLimitFactor()); (int)(expectedMaxApps * (queue.getUserLimit()/100.0f) *
queue.getUserLimitFactor()));
assertEquals(expectedMaxAppsPerUser, queue.getMaxApplicationsPerUser()); assertEquals(expectedMaxAppsPerUser, queue.getMaxApplicationsPerUser());
// should default to global setting if per queue setting not set // should default to global setting if per queue setting not set
@ -360,8 +361,8 @@ public class TestApplicationLimits {
assertEquals(9999, (int)csConf.getMaximumApplicationsPerQueue(queue.getQueuePath())); assertEquals(9999, (int)csConf.getMaximumApplicationsPerQueue(queue.getQueuePath()));
assertEquals(9999, queue.getMaxApplications()); assertEquals(9999, queue.getMaxApplications());
expectedMaxAppsPerUser = (int)(9999 * expectedMaxAppsPerUser = Math.min(9999, (int)(9999 *
(queue.getUserLimit()/100.0f) * queue.getUserLimitFactor()); (queue.getUserLimit()/100.0f) * queue.getUserLimitFactor()));
assertEquals(expectedMaxAppsPerUser, queue.getMaxApplicationsPerUser()); assertEquals(expectedMaxAppsPerUser, queue.getMaxApplicationsPerUser());
} }

View File

@ -433,8 +433,9 @@ public class TestRMWebServicesCapacitySched extends JerseyTestBase {
int maxSystemApps = csConf.getMaximumSystemApplications(); int maxSystemApps = csConf.getMaximumSystemApplications();
int expectedMaxApps = (int)(maxSystemApps * (info.absoluteCapacity/100)); int expectedMaxApps = (int)(maxSystemApps * (info.absoluteCapacity/100));
int expectedMaxAppsPerUser = int expectedMaxAppsPerUser = Math.min(expectedMaxApps,
(int)(expectedMaxApps * (info.userLimit/100.0f) * info.userLimitFactor); (int)(expectedMaxApps * (info.userLimit/100.0f) *
info.userLimitFactor));
// TODO: would like to use integer comparisons here but can't due to // TODO: would like to use integer comparisons here but can't due to
// roundoff errors in absolute capacity calculations // roundoff errors in absolute capacity calculations