4

我在 Fedora 17 上。我正在尝试使用与 Java 7 不兼容的 ant 构建文件编译项目。所以我决定安装 OpenJDK 6。不幸的是,JDK 6 已从 yum 存储库中删除,我认为它会是易于手动安装。我了解到没有 JAVA_HOME 变量,而是使用了替代系统。所以我下载了 OpenJDK 二进制文件(如果重要的话,从 OSG 下载)并使用alternatives --install命令安装了 java & javac & javaws。检查java --versionjavac --version证明它是成功的。但奇怪的是,蚂蚁不再工作了!当我键入时,ant --execdebug我收到此消息:

exec "/usr/lib/jvm/openjdk-6.0.24/bin/java" -classpath "/usr/bin/build-classpath: 
error: JVM_LIBDIR /usr/lib/jvm-exports/openjdk-6.0.24 does not exist or is not a 
directory:/usr/bin/build-classpath: error: JVM_LIBDIR /usr/lib/jvm-exports/openjdk-6.0.24 
does not exist or is not a directory:/usr/lib/jvm/openjdk-6.0.24/lib/tools.jar"
-Dant.home="/usr/share/ant" -Dant.library.dir="/usr/share/ant/lib" 
org.apache.tools.ant.launch.Launcher -cp ""
Exception in thread "main" java.lang.NoClassDefFoundError: org/apache/tools/ant/launch/Launcher
Caused by: java.lang.ClassNotFoundException: org.apache.tools.ant.launch.Launcher
    at java.net.URLClassLoader$1.run(URLClassLoader.java:217)
    at java.security.AccessController.doPrivileged(Native Method)
    at java.net.URLClassLoader.findClass(URLClassLoader.java:205)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:321)
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:294)
    at java.lang.ClassLoader.loadClass(ClassLoader.java:266)
Could not find the main class: org.apache.tools.ant.launch.Launcher. Program will exit.

与 java 一样,也没有 ANT_HOME 变量。但是,即使在安装 java 6 之前它工作正常,也没有 ANT_HOME。Ant 安装在 PATH 中已经存在的 /usr/bin/ant 下。

更新:我知道有类似的问题qustion 1question 2。但都没有解决我的问题。例如,添加 ANT_HOME=/usr/bin 会使情况恶化,因为即使使用 JDK 7,ant 也无法正常工作!由于我对替代系统不熟悉,我完全删除了与 java 相关的替代方案,添加了 JAVA_HOME,并改为修改了 PATH。同样,java 和 javac 工作正常, java --version 返回正确的版本,但 ant 返回相同的错误。正如--execdebug告诉我们的那样,JVM_LIBDIR 没有指向正确的位置。我想该值是在 java.conf 文件中设置的,所以我将它粘贴在这里(我在 /usr/lib/jvm 上安装了 JDK 6 和 7):

# System-wide Java configuration file                                -*- sh -*-
#
# JPackage Project <http://www.jpackage.org/>

# Location of jar files on the system
JAVA_LIBDIR=/usr/share/java

# Location of arch-specific jar files on the system
JNI_LIBDIR=/usr/lib64/java

# Location for noarch jar files using arch-specifics jar files
JAVAJNI_LIBDIR=/usr/share/java-jni

# Root of all JVM installations
JVM_ROOT=/usr/lib/jvm

# You can define a system-wide JVM root here if you're not using the
# default one.
#
# If you have the a base JRE package installed
# (e.g. java-1.6.0-openjdk):
#JAVA_HOME=$JVM_ROOT/jre
#
# If you have the a devel JDK package installed
# (e.g. java-1.6.0-openjdk-devel):
#JAVA_HOME=$JVM_ROOT/java-1.7.0-openjdk-1.7.0.9.x86_64
JAVA_HOME=$JVM_ROOT/openjdk-6.0.24

# Options to pass to the java interpreter
JAVACMD_OPTS=

通过仅在 java.conf 中注释和取消注释相应的行,它表明 ant 使用 7 可以正常工作,而使用 6 则失败。当我java在 ant shell 中的命令之前回显 JVM_LIBDIR 时,我收到user/share/java了 java.conf 中所述的信息。但是ant --execdebug又返回了一些奇怪的东西:JVM_LIBDIR /usr/lib/jvm-exports/openjdk-6.0.24。那是什么,我该如何解决?

如果您在这里无法说出问题,那么安装多个版本的 JDK 并且可以轻松切换的最简洁和最安全的方法是什么?

任何帮助都将不胜感激。

4

3 回答 3

6

您在类路径上缺少一个 jar。确保在 ant 从中获取依赖项的 lib 文件夹中拥有所有必需的库。

检查这个类似的问题。

于 2013-02-28T11:44:59.600 回答
2

我只能回答最后一个问题。

我们不使用替代系统,而是手动管理它。

我们在 Ubuntu 和 CentOS 中所做的是,我们总是使用 Oracle JDK 网站上的 tar.gz,将其解压缩到 /opt 中的子文件夹(如/opt/jdk_1.7.0_09),创建指向该文件夹的符号链接(如/opt/default_jdk -> /opt/jdk_1.7.0_09),并设置环境变量我们将 JAVA_HOME 指向符号链接而不是实际文件夹 ( JAVA_HOME=/opt/default_jdk)。

这样,如果我们要更改或更新jdk(例如从JDK 7 upadte 9 到JDK 7 upadte 15),我们只需下载tar.gz 包,将其解压缩到另一个文件夹(例如/opt/jdk_1.7.0_15),删除旧符号链接(指向/opt/jdk_1.7.0_09)并创建一个指向新文件夹的新文件夹(例如/opt/default_jdk -> /opt/jdk_1.7.0_15)。

同样的方式适用于 32 位和 64 位 jdks,不同版本的 Ant、Maven、Gradle 等。

于 2013-03-11T04:00:48.067 回答
1

看起来您的 Java 安装有问题。参考这个http://www.linuxforums.org/forum/red-hat-fedora-linux/151698-problems-tomcat.html有一个类似的问题,后来得到解决。

于 2013-03-14T02:48:53.000 回答