From e979a3ddb17f32582e36cdc9b826f06c80c473f2 Mon Sep 17 00:00:00 2001 From: Vinod Kumar Vavilapalli Date: Tue, 4 Oct 2011 09:37:56 +0000 Subject: [PATCH] MAPREDUCE-3056. Changed the default staging directory to not include user.name to prevent issues with non-secure mode. Contributed by Devaraj K. git-svn-id: https://svn.apache.org/repos/asf/hadoop/common/trunk@1178740 13f79535-47bb-0310-9956-ffa450edef68 --- hadoop-mapreduce-project/CHANGES.txt | 3 + .../hadoop/mapreduce/v2/app/MRAppMaster.java | 28 +++++-- .../mapreduce/v2/app/TestMRAppMaster.java | 76 +++++++++++++++++++ .../src/main/resources/mapred-default.xml | 2 +- 4 files changed, 102 insertions(+), 7 deletions(-) create mode 100644 hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/test/java/org/apache/hadoop/mapreduce/v2/app/TestMRAppMaster.java diff --git a/hadoop-mapreduce-project/CHANGES.txt b/hadoop-mapreduce-project/CHANGES.txt index 807e48608e..302d84f66a 100644 --- a/hadoop-mapreduce-project/CHANGES.txt +++ b/hadoop-mapreduce-project/CHANGES.txt @@ -1510,6 +1510,9 @@ Release 0.23.0 - Unreleased MAPREDUCE-3112. Fixed recursive sourcing of HADOOP_OPTS environment variable. (Eric Yang) + MAPREDUCE-3056. Changed the default staging directory to not include + user.name to prevent issues with non-secure mode. (Devaraj K via vinodkv) + Release 0.22.0 - Unreleased INCOMPATIBLE CHANGES diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/main/java/org/apache/hadoop/mapreduce/v2/app/MRAppMaster.java b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/main/java/org/apache/hadoop/mapreduce/v2/app/MRAppMaster.java index a2dadedaf1..be9a377611 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/main/java/org/apache/hadoop/mapreduce/v2/app/MRAppMaster.java +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/main/java/org/apache/hadoop/mapreduce/v2/app/MRAppMaster.java @@ -22,6 +22,7 @@ import java.io.File; import java.io.IOException; import java.lang.reflect.Constructor; import java.lang.reflect.InvocationTargetException; +import java.security.PrivilegedExceptionAction; import java.util.Map; import java.util.Set; import java.util.concurrent.ConcurrentHashMap; @@ -656,14 +657,29 @@ public class MRAppMaster extends CompositeService { new CompositeServiceShutdownHook(appMaster)); YarnConfiguration conf = new YarnConfiguration(new JobConf()); conf.addResource(new Path(MRJobConfig.JOB_CONF_FILE)); - conf.set(MRJobConfig.USER_NAME, - System.getProperty("user.name")); - UserGroupInformation.setConfiguration(conf); - appMaster.init(conf); - appMaster.start(); + String jobUserName = System + .getenv(ApplicationConstants.Environment.USER.name()); + conf.set(MRJobConfig.USER_NAME, jobUserName); + initAndStartAppMaster(appMaster, conf, jobUserName); } catch (Throwable t) { LOG.fatal("Error starting MRAppMaster", t); System.exit(1); } - } + } + + protected static void initAndStartAppMaster(final MRAppMaster appMaster, + final YarnConfiguration conf, String jobUserName) throws IOException, + InterruptedException { + UserGroupInformation.setConfiguration(conf); + UserGroupInformation appMasterUgi = UserGroupInformation + .createRemoteUser(jobUserName); + appMasterUgi.doAs(new PrivilegedExceptionAction() { + @Override + public Object run() throws Exception { + appMaster.init(conf); + appMaster.start(); + return null; + } + }); + } } diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/test/java/org/apache/hadoop/mapreduce/v2/app/TestMRAppMaster.java b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/test/java/org/apache/hadoop/mapreduce/v2/app/TestMRAppMaster.java new file mode 100644 index 0000000000..c21c4528fb --- /dev/null +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-app/src/test/java/org/apache/hadoop/mapreduce/v2/app/TestMRAppMaster.java @@ -0,0 +1,76 @@ +/** + * Licensed to the Apache Software Foundation (ASF) under one + * or more contributor license agreements. See the NOTICE file + * distributed with this work for additional information + * regarding copyright ownership. The ASF licenses this file + * to you under the Apache License, Version 2.0 (the + * "License"); you may not use this file except in compliance + * with the License. You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ +package org.apache.hadoop.mapreduce.v2.app; + +import java.io.IOException; + +import junit.framework.Assert; + +import org.apache.hadoop.conf.Configuration; +import org.apache.hadoop.fs.Path; +import org.apache.hadoop.mapreduce.MRJobConfig; +import org.apache.hadoop.mapreduce.v2.util.MRApps; +import org.apache.hadoop.security.UserGroupInformation; +import org.apache.hadoop.yarn.api.records.ApplicationAttemptId; +import org.apache.hadoop.yarn.conf.YarnConfiguration; +import org.apache.hadoop.yarn.util.ConverterUtils; +import org.junit.Test; + +public class TestMRAppMaster { + @Test + public void testMRAppMasterForDifferentUser() throws IOException, + InterruptedException { + String applicationAttemptIdStr = "appattempt_1317529182569_0004_000001"; + String stagingDir = "/tmp/staging"; + String userName = "TestAppMasterUser"; + ApplicationAttemptId applicationAttemptId = ConverterUtils + .toApplicationAttemptId(applicationAttemptIdStr); + MRAppMasterTest appMaster = new MRAppMasterTest(applicationAttemptId); + YarnConfiguration conf = new YarnConfiguration(); + conf.set(MRJobConfig.MR_AM_STAGING_DIR, stagingDir); + MRAppMaster.initAndStartAppMaster(appMaster, conf, userName); + Assert.assertEquals(stagingDir + Path.SEPARATOR + userName + Path.SEPARATOR + + ".staging", appMaster.stagingDirPath.toString()); + } +} + +class MRAppMasterTest extends MRAppMaster { + + Path stagingDirPath; + private Configuration conf; + + public MRAppMasterTest(ApplicationAttemptId applicationAttemptId) { + super(applicationAttemptId); + } + + @Override + public void init(Configuration conf) { + this.conf = conf; + } + + @Override + public void start() { + try { + String user = UserGroupInformation.getCurrentUser().getShortUserName(); + stagingDirPath = MRApps.getStagingAreaDir(conf, user); + } catch (Exception e) { + Assert.fail(e.getMessage()); + } + } + +} diff --git a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/resources/mapred-default.xml b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/resources/mapred-default.xml index f0d534da2a..496de9b44b 100644 --- a/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/resources/mapred-default.xml +++ b/hadoop-mapreduce-project/hadoop-mapreduce-client/hadoop-mapreduce-client-core/src/main/resources/mapred-default.xml @@ -1174,7 +1174,7 @@ yarn.app.mapreduce.am.staging-dir - /tmp/hadoop-yarn/${user.name}/staging + /tmp/hadoop-yarn/staging The staging dir used while submitting jobs.