From 952b26d7c5cff17c5dffbe304963ed6e3e182b0c Mon Sep 17 00:00:00 2001 From: Jian He Date: Fri, 19 May 2017 20:12:06 -0700 Subject: [PATCH] YARN-6627. Use deployed webapp folder to launch new YARN UI. Contributed by Sunil G --- .../resources/assemblies/hadoop-yarn-dist.xml | 5 ++- .../resourcemanager/ResourceManager.java | 34 ++++++++++++++----- 2 files changed, 29 insertions(+), 10 deletions(-) diff --git a/hadoop-assemblies/src/main/resources/assemblies/hadoop-yarn-dist.xml b/hadoop-assemblies/src/main/resources/assemblies/hadoop-yarn-dist.xml index 05e1a938488..74ce9bcf768 100644 --- a/hadoop-assemblies/src/main/resources/assemblies/hadoop-yarn-dist.xml +++ b/hadoop-assemblies/src/main/resources/assemblies/hadoop-yarn-dist.xml @@ -180,7 +180,7 @@ hadoop-yarn/hadoop-yarn-ui/target/hadoop-yarn-ui-${project.version} - /share/hadoop/${hadoop.component}/webapps/rm + /share/hadoop/${hadoop.component}/webapps/ui2 **/* @@ -188,6 +188,9 @@ + + org.apache.hadoop:hadoop-yarn-ui + share/hadoop/${hadoop.component} false diff --git a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/ResourceManager.java b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/ResourceManager.java index 1f5e8cd6061..8f2c121e6ef 100644 --- a/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/ResourceManager.java +++ b/hadoop-yarn-project/hadoop-yarn/hadoop-yarn-server/hadoop-yarn-server-resourcemanager/src/main/java/org/apache/hadoop/yarn/server/resourcemanager/ResourceManager.java @@ -113,6 +113,8 @@ import org.apache.zookeeper.server.auth.DigestAuthenticationProvider; import org.eclipse.jetty.webapp.WebAppContext; import com.google.common.annotations.VisibleForTesting; + +import java.io.FileNotFoundException; import java.io.IOException; import java.io.InputStream; import java.io.PrintStream; @@ -1068,33 +1070,47 @@ public class ResourceManager extends CompositeService implements Recoverable { WebAppContext uiWebAppContext = null; if (getConfig().getBoolean(YarnConfiguration.YARN_WEBAPP_UI2_ENABLE, YarnConfiguration.DEFAULT_YARN_WEBAPP_UI2_ENABLE)) { - String webPath = UI2_WEBAPP_NAME; String onDiskPath = getConfig() .get(YarnConfiguration.YARN_WEBAPP_UI2_WARFILE_PATH); + uiWebAppContext = new WebAppContext(); + uiWebAppContext.setContextPath(UI2_WEBAPP_NAME); + if (null == onDiskPath) { String war = "hadoop-yarn-ui-" + VersionInfo.getVersion() + ".war"; URLClassLoader cl = (URLClassLoader) ClassLoader.getSystemClassLoader(); URL url = cl.findResource(war); if (null == url) { - onDiskPath = ""; + onDiskPath = getWebAppsPath("ui2"); } else { onDiskPath = url.getFile(); } - - LOG.info( - "New web UI war file name:" + war + ", and path:" + onDiskPath); } - - uiWebAppContext = new WebAppContext(); - uiWebAppContext.setContextPath(webPath); - uiWebAppContext.setWar(onDiskPath); + if (onDiskPath == null || onDiskPath.isEmpty()) { + LOG.error("No war file or webapps found for ui2 !"); + } else { + if (onDiskPath.endsWith(".war")) { + uiWebAppContext.setWar(onDiskPath); + LOG.info("Using war file at: " + onDiskPath); + } else { + uiWebAppContext.setResourceBase(onDiskPath); + LOG.info("Using webapps at: " + onDiskPath); + } + } } webApp = builder.start(new RMWebApp(this), uiWebAppContext); } + private String getWebAppsPath(String appName) { + URL url = getClass().getClassLoader().getResource("webapps/" + appName); + if (url == null) { + return ""; + } + return url.toString(); + } + /** * Helper method to create and init {@link #activeServices}. This creates an * instance of {@link RMActiveServices} and initializes it.