aboutsummaryrefslogtreecommitdiff
path: root/common
diff options
context:
space:
mode:
authornfraison <nfraison@yahoo.fr>2016-03-28 14:10:25 -0700
committerMarcelo Vanzin <vanzin@cloudera.com>2016-03-28 14:10:25 -0700
commitff3bea38ed2ac8dac5832f0bf8eac70192a512ef (patch)
tree1dfe3aec3be1606c8e454ff54c08750419dfcb8f /common
parent7007f72ba7f0ccdc1d11315757a80f55a93451df (diff)
downloadspark-ff3bea38ed2ac8dac5832f0bf8eac70192a512ef.tar.gz
spark-ff3bea38ed2ac8dac5832f0bf8eac70192a512ef.tar.bz2
spark-ff3bea38ed2ac8dac5832f0bf8eac70192a512ef.zip
[SPARK-13622][YARN] Issue creating level db for YARN shuffle service
## What changes were proposed in this pull request? This patch will ensure that we trim all path set in yarn.nodemanager.local-dirs and that the the scheme is well removed so the level db can be created. ## How was this patch tested? manual tests. Author: nfraison <nfraison@yahoo.fr> Closes #11475 from ashangit/level_db_creation_issue.
Diffstat (limited to 'common')
-rw-r--r--common/network-yarn/src/main/java/org/apache/spark/network/yarn/YarnShuffleService.java7
1 files changed, 4 insertions, 3 deletions
diff --git a/common/network-yarn/src/main/java/org/apache/spark/network/yarn/YarnShuffleService.java b/common/network-yarn/src/main/java/org/apache/spark/network/yarn/YarnShuffleService.java
index ba6d30a74c..4bc3c1a3c8 100644
--- a/common/network-yarn/src/main/java/org/apache/spark/network/yarn/YarnShuffleService.java
+++ b/common/network-yarn/src/main/java/org/apache/spark/network/yarn/YarnShuffleService.java
@@ -24,6 +24,7 @@ import java.util.List;
import com.google.common.annotations.VisibleForTesting;
import com.google.common.collect.Lists;
import org.apache.hadoop.conf.Configuration;
+import org.apache.hadoop.fs.Path;
import org.apache.hadoop.yarn.api.records.ContainerId;
import org.apache.hadoop.yarn.server.api.*;
import org.slf4j.Logger;
@@ -118,7 +119,7 @@ public class YarnShuffleService extends AuxiliaryService {
// an application was stopped while the NM was down, we expect yarn to call stopApplication()
// when it comes back
registeredExecutorFile =
- findRegisteredExecutorFile(conf.getStrings("yarn.nodemanager.local-dirs"));
+ findRegisteredExecutorFile(conf.getTrimmedStrings("yarn.nodemanager.local-dirs"));
TransportConf transportConf = new TransportConf("shuffle", new HadoopConfigProvider(conf));
// If authentication is enabled, set up the shuffle server to use a
@@ -191,12 +192,12 @@ public class YarnShuffleService extends AuxiliaryService {
private File findRegisteredExecutorFile(String[] localDirs) {
for (String dir: localDirs) {
- File f = new File(dir, "registeredExecutors.ldb");
+ File f = new File(new Path(dir).toUri().getPath(), "registeredExecutors.ldb");
if (f.exists()) {
return f;
}
}
- return new File(localDirs[0], "registeredExecutors.ldb");
+ return new File(new Path(localDirs[0]).toUri().getPath(), "registeredExecutors.ldb");
}
/**