From bb8446e80cededeb577bd26db76086bfe31fc340 Mon Sep 17 00:00:00 2001 From: Adam Antal Date: Thu, 1 Oct 2020 11:42:04 +0200 Subject: [PATCH] YARN-10447. TestLeafQueue: ActivitiesManager thread might interfere with ongoing stubbing. Contributed by Peter Bacsko --- .../scheduler/capacity/CapacityScheduler.java | 20 ++++++++++++++++--- .../scheduler/capacity/TestLeafQueue.java | 1 + 2 files changed, 18 insertions(+), 3 deletions(-) diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/CapacityScheduler.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/CapacityScheduler.java index 678fd2d6f8b..5a7db5826c8 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/CapacityScheduler.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/CapacityScheduler.java @@ -245,6 +245,8 @@ public class CapacityScheduler extends private CSMaxRunningAppsEnforcer maxRunningEnforcer; + private boolean activitiesManagerEnabled = true; + public CapacityScheduler() { super(CapacityScheduler.class.getName()); this.maxRunningEnforcer = new CSMaxRunningAppsEnforcer(this); @@ -342,7 +344,9 @@ public class CapacityScheduler extends this.workflowPriorityMappingsMgr = new WorkflowPriorityMappingsManager(); this.activitiesManager = new ActivitiesManager(rmContext); - activitiesManager.init(conf); + if (activitiesManagerEnabled) { + activitiesManager.init(conf); + } initializeQueues(this.conf); this.isLazyPreemptionEnabled = conf.getLazyPreemptionEnabled(); @@ -400,7 +404,9 @@ public class CapacityScheduler extends private void startSchedulerThreads() { writeLock.lock(); try { - activitiesManager.start(); + if (activitiesManagerEnabled) { + activitiesManager.start(); + } if (scheduleAsynchronously) { Preconditions.checkNotNull(asyncSchedulerThreads, "asyncSchedulerThreads is null"); @@ -434,7 +440,9 @@ public class CapacityScheduler extends public void serviceStop() throws Exception { writeLock.lock(); try { - this.activitiesManager.stop(); + if (activitiesManagerEnabled) { + this.activitiesManager.stop(); + } if (scheduleAsynchronously && asyncSchedulerThreads != null) { for (Thread t : asyncSchedulerThreads) { t.interrupt(); @@ -3286,6 +3294,7 @@ public class CapacityScheduler extends this.maxRunningEnforcer = enforcer; } + /** * Returning true as capacity scheduler supports placement constraints. */ @@ -3293,4 +3302,9 @@ public class CapacityScheduler extends public boolean placementConstraintEnabled() { return true; } + + @VisibleForTesting + public void setActivitiesManagerEnabled(boolean enabled) { + this.activitiesManagerEnabled = enabled; + } } diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/TestLeafQueue.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/TestLeafQueue.java index 3bfb0ab6889..02545cbc325 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/TestLeafQueue.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/test/java/org/apache/hadoop/yarn/server/resourcemanager/scheduler/capacity/TestLeafQueue.java @@ -162,6 +162,7 @@ public class TestLeafQueue { private void setUpInternal(ResourceCalculator rC, boolean withNodeLabels) throws Exception { CapacityScheduler spyCs = new CapacityScheduler(); + spyCs.setActivitiesManagerEnabled(false); queues = new CSQueueStore(); cs = spy(spyCs); rmContext = TestUtils.getMockRMContext();