Maven从源代码安装Hadoop,查找tools.jar的错误路径

时间:2014-05-31 14:33:10

标签: java maven hadoop

我正在尝试构建hadoop-2.4.0-src,使用' mvn clean install'。大约一半成功完成,但HDFS projetc失败了:

Exception in thread "main" java.lang.AssertionError: Missing tools.jar at: /Library/Java/JavaVirtualMachines/jdk1.7.0_55.jdk/Contents/Home/Classes/classes.jar. Expression: file.exists()

....../Home/Classes/不存在,tools.jar位于......../Home/lib。我的$JAVA_HOME环境变量肯定设置正确,错误消息中列出的JDK是正确的 - 它只是在该路径中查找错误的位置。我看过一些帖子,一个常见的问题是人们使用的是JRE而不是JDK,但我确信我的是JDK。

我已经从接受的答案中尝试了两个建议: Buiding Hadoop with Eclipse / Maven - Missing artifact jdk.tools:jdk.tools:jar:1.6

......没有成功。添加'依赖'阻止Hadoop的pom.xml没有效果,对于第二个建议,我将相关的版本号从1.6更改为1.7。我也尝试过类似问题的各种其他建议而没有成功。

which返回我的期望:

$ which javac
/Library/Java/JavaVirtualMachines/jdk1.7.0_55.jdk/Contents/Home/bin/javac

然而,JavaVM.framework / Versions的内容对我来说似乎很奇怪,因为它似乎没有列出1.7:

/System/Library/Frameworks/JavaVM.framework/Versions $ ls -al
total 64
drwxr-xr-x  11 root  wheel  374 May 10 11:05 ./
drwxr-xr-x  12 root  wheel  408 May 10 11:05 ../
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.4@ -> CurrentJDK
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.4.2@ -> CurrentJDK
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.5@ -> CurrentJDK
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.5.0@ -> CurrentJDK
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.6@ -> CurrentJDK
lrwxr-xr-x   1 root  wheel   10 May 10 11:05 1.6.0@ -> CurrentJDK
drwxr-xr-x   8 root  wheel  272 May 10 11:05 A/
lrwxr-xr-x   1 root  wheel    1 May 10 11:05 Current@ -> A
lrwxr-xr-x   1 root  wheel   59 May 10 11:05 CurrentJDK@ -> /System/Library/Java/JavaVirtualMachines/1.6.0.jdk/Contents

我对Java比较陌生,所以我无法弄清楚问题的根源在哪里 - 是我的本地目录树,如Versions的奇怪内容所示? Java配置不正确(尽管我已经在Eclipse中使用Java 1.7几周了但没有问题)?或者这是Hadoop的pom.xml的问题我需要以某种方式更新吗?

感谢您的帮助。

1 个答案:

答案 0 :(得分:9)

在我的mac上解决以下问题:

cd /Library/Java/JavaVirtualMachines/jdk1.7.0_55.jdk/Contents/Home/ 
sudo mkdir Classes 
cd Classes/ 
sudo ln -s ../jre/lib/rt.jar classes.jar

价: http://ilovemylinux.blogspot.com/2013/05/maven-jspc-compile-error-with-java-7-on.html