gpt4 book ai didi

java - Ant 不使用我的 JAVA_HOME 来查找 tools.jar

转载 作者:太空宇宙 更新时间:2023-11-04 09:13:43 24 4
gpt4 key购买 nike

我意识到这个问题最初听起来像是与其他一些问题的重复,但我看过的其他问题都没有解决我的问题。

简而言之,我在不同位置安装了一个 JRE 和一个 JDK。我将 JAVA_HOME 设置为指向 JDK,但 ant 似乎仍在 JRE 位置搜索 tools.jar。我不确定这是否与我的 ant 安装/配置或我的 JDK 安装/配置有关。

长话短说:

环境

我在 Red Hat Enterprise Linux Server 7.5 (Maipo) 上运行的帐户没有任何 sudo 权限。

我的 JDK 安装

机器已经在 /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/jre/bin/java 安装了 JRE .我不允许修改该安装,但我可以在单独的位置创建我自己的 java 安装。

我的网络安全要求非常严格,我只能在机器上安装特定的软件。可以为其他软件请求许可,但我必须经历一个非常痛苦的批准过程。我已获得将 openJDK 中的 JDK 1.8 安装到机器上的许可。

由于 openJDK 不会发布整个安装的 tar 包,而且我没有 sudo 权限,所以我尝试通过下载 java-1.8.0-openjdk-1.8.0.172-13.b11 来安装 JDK。 fc29.x86_64.rpmjava-1.8.0-openjdk-devel-1.8.0.172-13.b11.fc29.x86_64.rpm/local/apps/openJDK8 并运行(来自 /local/apps/openJDK8)

rpm2cpio < java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64.rpm | cpio -i --make-directories
rpm2cpio < java-1.8.0-openjdk-devel-1.8.0.172-13.b11.fc29.x86_64.rpm | cpio -i --make-directories

出于某种原因,这似乎没有完成 JDK 安装(我想我一定是缺少一些依赖项)。我发现 libjava.so、libjvm.so、jvm.cfg 和服务器文件夹丢失了,所以我创建了一些指向包含它们的 JRE 安装的链接(从 local/apps/openJDK8 运行) ):

ln -s /usr/lib/jvm/jre-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/amd64/jvm.cfg usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/lib/amd64/jvm.cfg
ln -s /usr/lib/jvm/jre-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/amd64/libjava.so usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/lib/amd64/libjava.so
ln -s /usr/lib/jvm/jre-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/amd64/libjvm.so usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/lib/amd64/libjvm.so
ln -s /usr/lib/jvm/jre-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/amd64/server usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/lib/amd64/server

这一步让我有点紧张,所以这可能是我问题的一部分。无论如何,javac 和 java 似乎工作正常。

Ant 安装

对于我的 ant 安装,我只是下载了一个 tar ball 并将其解压到 /local/apps/ant 然后做了:

export JAVA_HOME=/local/apps/openJDK8/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64
export ANT_HOME=/local/apps/ant/apache-ant-1.10.4

我没有费心更新路径,因为现在我只是对所有内容使用完全限定的路径。我的最终目标是让 Jenkins 运行所有这些,并且它只使用完全限定的路径。

结果

现在,如果我尝试运行 ant,我会得到:

> /local/apps/ant/apache-ant-1.10.4/bin/ant
Unable to locate tools.jar. Expected to find it in /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/tools.jar
Buildfile: build.xml does not exist!
Build failed

build.xml does not exist部分当然是意料之中的,但是无法定位tools.jar的问题需要解决。对我来说最奇怪的是,根据错误信息,它实际上是在JRE安装位置寻找它。

由于 ant 本身只是一个 shell 脚本,我修改了它以打印出更多信息,方法是在文件末尾添加以下行,使其看起来像这样:

echo Running $ant_exec_command $ant_exec_args
echo JAVA_HOME = $JAVA_HOME
echo JAVACMD = $JAVACMD
echo CLASSPATH = $CLASSPATH
echo LOCALCLASSPATH = $LOCALCLASSPATH
echo ANT_HOME = $ANT_HOME
echo ANT_LIB = $ANT_LIB
eval "$ant_exec_command $ant_exec_args"

现在的输出是:

$ /local/apps/ant/apache-ant-1.10.4/bin/ant
JAVA_HOME is /local/apps/openJDK8/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64
Running exec "$JAVACMD" -classpath "$LOCALCLASSPATH" -Dant.home="$ANT_HOME" -Dant.library.dir="$ANT_LIB" org.apache.tools.ant.launch.Launcher -cp "$CLASSPATH"
JAVA_HOME = /local/apps/openJDK8/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64
JAVACMD = /local/apps/openJDK8/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/bin/java
CLASSPATH =
LOCALCLASSPATH = /local/apps/ant/apache-ant-1.10.4/lib/ant-launcher.jar
ANT_HOME = /local/apps/ant/apache-ant-1.10.4
ANT_LIB = /local/apps/ant/apache-ant-1.10.4/lib
Unable to locate tools.jar. Expected to find it in /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/tools.jar
Buildfile: build.xml does not exist!
Build failed

这样JAVA_HOME就明确设置好了。我什至可以进一步验证 ant 实际上正在使用我至少为某些事情设置的 JAVA_HOME 值,因为如果我删除我在 JDK 安装中创建的所有这些链接,它会提示它不能'找不到 libjava.so

很明显,ant 至少使用了我的 JDK 安装,但仍在旧的 JRE 安装中寻找 tools.jar

对正在发生的事情有什么想法吗?

最佳答案

想通了:)

与实际修复相比,此修复感觉更像是一种变通方法,因此如果其他人有更好的解决方案,我很想听听。

我稍微浏览了一下 ant 源代码,发现 ant 有一个很有用的 --launchdiag 属性。运行它给了我:

/local/apps/openJDK8/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.172-13.b11.fc29.x86_64/bin/java -classpath /local/apps/ant/apache-ant-1.10.4/lib/ant-launcher.jar -Dant.home=/local/apps/ant/apache-ant-1.10.4 -Dant.library.dir=/local/apps/ant/apache-ant-1.10.4/lib org.apache.tools.ant.launch.Launcher --launchdiag
Launcher JAR= "/local/apps/ant/apache-ant-1.10.4/lib/ant-launcher.jar"
Launcher JAR directory= "/local/apps/ant/apache-ant-1.10.4/lib"
java.home= "/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/jre"
Unable to locate tools.jar. Expected to find it in /usr/lib/jvm/java-1.8.0-openjdk-1.8.0.171-7.b10.el7.x86_64/lib/tools.jar
tools.jar= "null"
Setting "java.class.path" to "/local/apps/ant/apache-ant-1.10.4/lib/ant-launcher.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-antlr.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-swing.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-testutil.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-xalan2.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-junitlauncher.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-xz.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-junit.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-log4j.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-javamail.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-bsf.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-resolver.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-oro.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-bcel.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-jai.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-jsch.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-jmf.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-commons-logging.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-launcher.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-jdepend.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-commons-net.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-netrexx.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-junit4.jar:/local/apps/ant/apache-ant-1.10.4/lib/ant-apache-regexp.jar"
Buildfile: build.xml does not exist!
Build failed

在代码中我发现 java.home 属性来自 System.getProperty("java.home") 这显然与 JAVA_HOME

通过添加 -Djava.home=$JAVA_HOME 我能够让它工作

关于java - Ant 不使用我的 JAVA_HOME 来查找 tools.jar,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51290887/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com