YARN-1912. ResourceLocalizer started without any jvm memory control.
Contributed by Masatake Iwasaki
(cherry picked from commit 6471d18bc7
)
This commit is contained in:
parent
fc980247a6
commit
acb342b77c
|
@ -170,6 +170,9 @@ Release 2.8.0 - UNRELEASED
|
||||||
YARN-3271. FairScheduler: Move tests related to max-runnable-apps from
|
YARN-3271. FairScheduler: Move tests related to max-runnable-apps from
|
||||||
TestFairScheduler to TestAppRunnability. (nijel via kasha)
|
TestFairScheduler to TestAppRunnability. (nijel via kasha)
|
||||||
|
|
||||||
|
YARN-1912. ResourceLocalizer started without any jvm memory control.
|
||||||
|
(Masatake Iwasaki via xgong)
|
||||||
|
|
||||||
OPTIMIZATIONS
|
OPTIMIZATIONS
|
||||||
|
|
||||||
YARN-3339. TestDockerContainerExecutor should pull a single image and not
|
YARN-3339. TestDockerContainerExecutor should pull a single image and not
|
||||||
|
|
|
@ -1004,6 +1004,13 @@ public class YarnConfiguration extends Configuration {
|
||||||
public static final String NM_HEALTH_CHECK_SCRIPT_OPTS =
|
public static final String NM_HEALTH_CHECK_SCRIPT_OPTS =
|
||||||
NM_PREFIX + "health-checker.script.opts";
|
NM_PREFIX + "health-checker.script.opts";
|
||||||
|
|
||||||
|
/** The JVM options used on forking ContainerLocalizer process
|
||||||
|
by container executor. */
|
||||||
|
public static final String NM_CONTAINER_LOCALIZER_JAVA_OPTS_KEY =
|
||||||
|
NM_PREFIX + "container-localizer.java.opts";
|
||||||
|
public static final String NM_CONTAINER_LOCALIZER_JAVA_OPTS_DEFAULT =
|
||||||
|
"-Xmx256m";
|
||||||
|
|
||||||
/** The Docker image name(For DockerContainerExecutor).*/
|
/** The Docker image name(For DockerContainerExecutor).*/
|
||||||
public static final String NM_DOCKER_CONTAINER_EXECUTOR_IMAGE_NAME =
|
public static final String NM_DOCKER_CONTAINER_EXECUTOR_IMAGE_NAME =
|
||||||
NM_PREFIX + "docker-container-executor.image-name";
|
NM_PREFIX + "docker-container-executor.image-name";
|
||||||
|
|
|
@ -246,6 +246,7 @@ public class LinuxContainerExecutor extends ContainerExecutor {
|
||||||
if (javaLibPath != null) {
|
if (javaLibPath != null) {
|
||||||
command.add("-Djava.library.path=" + javaLibPath);
|
command.add("-Djava.library.path=" + javaLibPath);
|
||||||
}
|
}
|
||||||
|
command.addAll(ContainerLocalizer.getJavaOpts(getConf()));
|
||||||
buildMainArgs(command, user, appId, locId, nmAddr, localDirs);
|
buildMainArgs(command, user, appId, locId, nmAddr, localDirs);
|
||||||
String[] commandArray = command.toArray(new String[command.size()]);
|
String[] commandArray = command.toArray(new String[command.size()]);
|
||||||
ShellCommandExecutor shExec = new ShellCommandExecutor(commandArray);
|
ShellCommandExecutor shExec = new ShellCommandExecutor(commandArray);
|
||||||
|
|
|
@ -697,7 +697,8 @@ public class WindowsSecureContainerExecutor extends DefaultContainerExecutor {
|
||||||
if (javaLibPath != null) {
|
if (javaLibPath != null) {
|
||||||
command.add("-Djava.library.path=" + javaLibPath);
|
command.add("-Djava.library.path=" + javaLibPath);
|
||||||
}
|
}
|
||||||
|
command.addAll(ContainerLocalizer.getJavaOpts(getConf()));
|
||||||
|
|
||||||
ContainerLocalizer.buildMainArgs(command, user, appId, locId, nmAddr,
|
ContainerLocalizer.buildMainArgs(command, user, appId, locId, nmAddr,
|
||||||
localDirs);
|
localDirs);
|
||||||
|
|
||||||
|
|
|
@ -55,6 +55,7 @@ import org.apache.hadoop.util.DiskChecker;
|
||||||
import org.apache.hadoop.yarn.YarnUncaughtExceptionHandler;
|
import org.apache.hadoop.yarn.YarnUncaughtExceptionHandler;
|
||||||
import org.apache.hadoop.yarn.api.records.LocalResource;
|
import org.apache.hadoop.yarn.api.records.LocalResource;
|
||||||
import org.apache.hadoop.yarn.api.records.SerializedException;
|
import org.apache.hadoop.yarn.api.records.SerializedException;
|
||||||
|
import org.apache.hadoop.yarn.conf.YarnConfiguration;
|
||||||
import org.apache.hadoop.yarn.exceptions.YarnException;
|
import org.apache.hadoop.yarn.exceptions.YarnException;
|
||||||
import org.apache.hadoop.yarn.factories.RecordFactory;
|
import org.apache.hadoop.yarn.factories.RecordFactory;
|
||||||
import org.apache.hadoop.yarn.factory.providers.RecordFactoryProvider;
|
import org.apache.hadoop.yarn.factory.providers.RecordFactoryProvider;
|
||||||
|
@ -312,7 +313,17 @@ public class ContainerLocalizer {
|
||||||
status.addAllResources(currentResources);
|
status.addAllResources(currentResources);
|
||||||
return status;
|
return status;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the JVM options to to launch the resource localizer.
|
||||||
|
* @param conf the configuration properties to launch the resource localizer.
|
||||||
|
*/
|
||||||
|
public static List<String> getJavaOpts(Configuration conf) {
|
||||||
|
String opts = conf.get(YarnConfiguration.NM_CONTAINER_LOCALIZER_JAVA_OPTS_KEY,
|
||||||
|
YarnConfiguration.NM_CONTAINER_LOCALIZER_JAVA_OPTS_DEFAULT);
|
||||||
|
return Arrays.asList(opts.split(" "));
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Adds the ContainerLocalizer arguments for a @{link ShellCommandExecutor},
|
* Adds the ContainerLocalizer arguments for a @{link ShellCommandExecutor},
|
||||||
* as expected by ContainerLocalizer.main
|
* as expected by ContainerLocalizer.main
|
||||||
|
|
|
@ -186,19 +186,20 @@ public class TestLinuxContainerExecutorWithMocks {
|
||||||
try {
|
try {
|
||||||
mockExec.startLocalizer(nmPrivateCTokensPath, address, "test", "application_0", "12345", dirsHandler);
|
mockExec.startLocalizer(nmPrivateCTokensPath, address, "test", "application_0", "12345", dirsHandler);
|
||||||
List<String> result=readMockParams();
|
List<String> result=readMockParams();
|
||||||
Assert.assertEquals(result.size(), 17);
|
Assert.assertEquals(result.size(), 18);
|
||||||
Assert.assertEquals(result.get(0), YarnConfiguration.DEFAULT_NM_NONSECURE_MODE_LOCAL_USER);
|
Assert.assertEquals(result.get(0), YarnConfiguration.DEFAULT_NM_NONSECURE_MODE_LOCAL_USER);
|
||||||
Assert.assertEquals(result.get(1), "test");
|
Assert.assertEquals(result.get(1), "test");
|
||||||
Assert.assertEquals(result.get(2), "0" );
|
Assert.assertEquals(result.get(2), "0" );
|
||||||
Assert.assertEquals(result.get(3),"application_0" );
|
Assert.assertEquals(result.get(3),"application_0" );
|
||||||
Assert.assertEquals(result.get(4), "/bin/nmPrivateCTokensPath");
|
Assert.assertEquals(result.get(4), "/bin/nmPrivateCTokensPath");
|
||||||
Assert.assertEquals(result.get(8), "-classpath" );
|
Assert.assertEquals(result.get(8), "-classpath" );
|
||||||
Assert.assertEquals(result.get(11),"org.apache.hadoop.yarn.server.nodemanager.containermanager.localizer.ContainerLocalizer" );
|
Assert.assertEquals(result.get(11), "-Xmx256m" );
|
||||||
Assert.assertEquals(result.get(12), "test");
|
Assert.assertEquals(result.get(12),"org.apache.hadoop.yarn.server.nodemanager.containermanager.localizer.ContainerLocalizer" );
|
||||||
Assert.assertEquals(result.get(13), "application_0");
|
Assert.assertEquals(result.get(13), "test");
|
||||||
Assert.assertEquals(result.get(14),"12345" );
|
Assert.assertEquals(result.get(14), "application_0");
|
||||||
Assert.assertEquals(result.get(15),"localhost" );
|
Assert.assertEquals(result.get(15),"12345" );
|
||||||
Assert.assertEquals(result.get(16),"8040" );
|
Assert.assertEquals(result.get(16),"localhost" );
|
||||||
|
Assert.assertEquals(result.get(17),"8040" );
|
||||||
|
|
||||||
} catch (InterruptedException e) {
|
} catch (InterruptedException e) {
|
||||||
LOG.error("Error:"+e.getMessage(),e);
|
LOG.error("Error:"+e.getMessage(),e);
|
||||||
|
|
Loading…
Reference in New Issue