From f2fa736f0ab139b5251d115fd75b833d1d7d1dcd Mon Sep 17 00:00:00 2001 From: Billie Rinaldi Date: Fri, 26 Jan 2018 09:32:23 -0800 Subject: [PATCH] YARN-7797. Docker host network can not obtain IP address for RegistryDNS. Contributed by Eric Yang --- .../runtime/DockerLinuxContainerRuntime.java | 28 +++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/runtime/DockerLinuxContainerRuntime.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/runtime/DockerLinuxContainerRuntime.java index 2868dea0ee..f3ce73db69 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/runtime/DockerLinuxContainerRuntime.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-nodemanager/src/main/java/org/apache/hadoop/yarn/server/nodemanager/containermanager/linux/runtime/DockerLinuxContainerRuntime.java @@ -58,6 +58,8 @@ import org.apache.hadoop.yarn.server.nodemanager.containermanager.runtime.ContainerRuntimeConstants; import org.apache.hadoop.yarn.server.nodemanager.containermanager.runtime.ContainerRuntimeContext; +import java.net.InetAddress; +import java.net.UnknownHostException; import java.nio.file.Files; import java.nio.file.Paths; import java.util.ArrayList; @@ -1013,6 +1015,32 @@ public String[] getIpAndHost(Container container) { } String ips = output.substring(0, index).trim(); String host = output.substring(index+1).trim(); + if (ips.equals("")) { + String network; + try { + network = container.getLaunchContext().getEnvironment() + .get("YARN_CONTAINER_RUNTIME_DOCKER_CONTAINER_NETWORK"); + if (network == null || network.isEmpty()) { + network = defaultNetwork; + } + } catch (NullPointerException e) { + network = defaultNetwork; + } + boolean useHostNetwork = network.equalsIgnoreCase("host"); + if (useHostNetwork) { + // Report back node manager IP in the event where docker + // inspect reports no IP address. This is for bridging a gap for + // docker environment to run with host network. + InetAddress address; + try { + address = InetAddress.getLocalHost(); + ips = address.getHostAddress(); + } catch (UnknownHostException e) { + LOG.error("Can not determine IP for container:" + + containerId); + } + } + } String[] ipAndHost = new String[2]; ipAndHost[0] = ips; ipAndHost[1] = host;