YARN-7289. Application lifetime does not work with FairScheduler. Contributed by Miklos Szegedi.

(cherry picked from commit 5c799ecf09)
This commit is contained in:
Rohith Sharma K S 2017-10-27 22:46:38 +05:30
parent 88c3b444bd
commit 548116c3f5
2 changed files with 50 additions and 15 deletions

View File

@ -1858,4 +1858,10 @@ public class FairScheduler extends
ReadLock getSchedulerReadLock() { ReadLock getSchedulerReadLock() {
return this.readLock; return this.readLock;
} }
@Override
public long checkAndGetApplicationLifetime(String queueName, long lifetime) {
// Lifetime is the application lifetime by default.
return lifetime;
}
} }

View File

@ -22,7 +22,9 @@ import static org.junit.Assert.assertTrue;
import static org.junit.Assert.fail; import static org.junit.Assert.fail;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList;
import java.util.Arrays; import java.util.Arrays;
import java.util.Collection;
import java.util.Collections; import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.Map; import java.util.Map;
@ -54,6 +56,7 @@ import org.apache.hadoop.yarn.server.resourcemanager.rmnode.RMNodeImpl;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.ResourceScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacityScheduler;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration; import org.apache.hadoop.yarn.server.resourcemanager.scheduler.capacity.CapacitySchedulerConfiguration;
import org.apache.hadoop.yarn.server.resourcemanager.scheduler.fair.FairScheduler;
import org.apache.hadoop.yarn.util.Times; import org.apache.hadoop.yarn.util.Times;
import org.apache.log4j.Level; import org.apache.log4j.Level;
import org.apache.log4j.LogManager; import org.apache.log4j.LogManager;
@ -61,19 +64,36 @@ import org.apache.log4j.Logger;
import org.junit.Assert; import org.junit.Assert;
import org.junit.Before; import org.junit.Before;
import org.junit.Test; import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.Parameterized;
/** /**
* Test class for application life time monitor feature test. * Test class for application life time monitor feature test.
*/ */
@RunWith(Parameterized.class)
public class TestApplicationLifetimeMonitor { public class TestApplicationLifetimeMonitor {
private YarnConfiguration conf; private YarnConfiguration conf;
@Parameterized.Parameters
public static Collection<Object[]> data() {
Collection<Object[]> params = new ArrayList<Object[]>();
params.add(new Object[]{CapacityScheduler.class});
params.add(new Object[]{FairScheduler.class});
return params;
}
private Class scheduler;
public TestApplicationLifetimeMonitor(Class schedulerParameter) {
scheduler = schedulerParameter;
}
@Before @Before
public void setup() throws IOException { public void setup() throws IOException {
conf = new YarnConfiguration(); conf = new YarnConfiguration();
// Always run for CS, since other scheduler do not support this. // Always run for CS, since other scheduler do not support this.
conf.setClass(YarnConfiguration.RM_SCHEDULER, conf.setClass(YarnConfiguration.RM_SCHEDULER,
CapacityScheduler.class, ResourceScheduler.class); scheduler, ResourceScheduler.class);
Logger rootLogger = LogManager.getRootLogger(); Logger rootLogger = LogManager.getRootLogger();
rootLogger.setLevel(Level.DEBUG); rootLogger.setLevel(Level.DEBUG);
UserGroupInformation.setConfiguration(conf); UserGroupInformation.setConfiguration(conf);
@ -82,15 +102,20 @@ public class TestApplicationLifetimeMonitor {
} }
@Test(timeout = 60000) @Test(timeout = 60000)
public void testApplicationLifetimeMonitor() throws Exception { public void testApplicationLifetimeMonitor()
throws Exception {
MockRM rm = null; MockRM rm = null;
try { try {
long maxLifetime = 30L; long maxLifetime = 30L;
long defaultLifetime = 15L; long defaultLifetime = 15L;
YarnConfiguration newConf = YarnConfiguration newConf;
new YarnConfiguration(setUpCSQueue(maxLifetime, defaultLifetime)); if (scheduler.equals(CapacityScheduler.class)) {
conf = new YarnConfiguration(newConf); // Since there is limited lifetime monitoring support in fair scheduler
// it does not need queue setup
conf =
new YarnConfiguration(setUpCSQueue(maxLifetime, defaultLifetime));
}
rm = new MockRM(conf); rm = new MockRM(conf);
rm.start(); rm.start();
@ -173,17 +198,21 @@ public class TestApplicationLifetimeMonitor {
Assert.assertTrue("Application killed before lifetime value", Assert.assertTrue("Application killed before lifetime value",
app2.getFinishTime() > afterUpdate); app2.getFinishTime() > afterUpdate);
rm.waitForState(app3.getApplicationId(), RMAppState.KILLED); if (scheduler.equals(CapacityScheduler.class)) {
// Supported only on capacity scheduler
rm.waitForState(app3.getApplicationId(), RMAppState.KILLED);
// app4 submitted exceeding queue max lifetime, so killed after queue max // app4 submitted exceeding queue max lifetime,
// lifetime. // so killed after queue max lifetime.
rm.waitForState(app4.getApplicationId(), RMAppState.KILLED); rm.waitForState(app4.getApplicationId(), RMAppState.KILLED);
long totalTimeRun = (app4.getFinishTime() - app4.getSubmitTime()) / 1000; long totalTimeRun =
Assert.assertTrue("Application killed before lifetime value", (app4.getFinishTime() - app4.getSubmitTime()) / 1000;
totalTimeRun > maxLifetime); Assert.assertTrue("Application killed before lifetime value",
Assert.assertTrue( totalTimeRun > maxLifetime);
"Application killed before lifetime value " + totalTimeRun, Assert.assertTrue(
totalTimeRun < maxLifetime + 10L); "Application killed before lifetime value " + totalTimeRun,
totalTimeRun < maxLifetime + 10L);
}
} finally { } finally {
stopRM(rm); stopRM(rm);
} }