Maven中的Java_home

时间:2013-03-07 19:03:32

标签: windows maven java java-home

当我运行mvn -version时,我注意到java_home指向...jdk\jre(如下所示)。 那是错的吗?是不是应该指向...\jdk.x.y.z(没有\jre)? 如果是这样,我该如何重置它? (在全局%java_home%指向jdk目录)

C:\Users\Owner>mvn -version
Apache Maven 2.2.1 (r801777; 2009-08-06 15:16:01-0400)
Java version: 1.7.0_17
Java home: C:\Program Files\Java\jdk1.7.0_17\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7" version: "6.1" arch: "amd64" Family: "windows"

2 个答案:

答案 0 :(得分:60)

不,这没错。它指向JDK使用的JRE,这是它应该的。如果您在maven外打印JAVA_HOME,它应该打印正确:

C:\>echo %JAVA_HOME%
C:\Program Files\Java\jdk1.7.0_07

C:\>mvn -version
Apache Maven 3.0.4 (r1232337; 2012-01-17 10:44:56+0200)
Maven home: C:\APPS\apache-maven-3.0.4\bin\..
Java version: 1.7.0_07, vendor: Oracle Corporation
Java home: C:\Program Files\Java\jdk1.7.0_07\jre
Default locale: en_US, platform encoding: Cp1252
OS name: "windows 7", version: "6.1", arch: "amd64", family: "windows"
C:\>

所以基本上JAVA_HOME需要指向JDK安装(maven需要tools.jar),但是maven实际上使用JDK中的jre来运行它。

使用mvn -version时,maven使用java内部java.home属性,如source code所示:

version.append( "Java home: " + System.getProperty( "java.home", "<unknown java home>" ) ).append( LS );

此属性与JAVA_HOME环境设置不同,因此可能会欺骗您。它实际上是动态属性,显示哪个JRE正在运行您的代码。如果您编译并执行打印相同的Test.java测试类,您可以看到如果您的JAVA_HOME指向JDK,则java.home的值不等于您的JAVA_HOME。这是预期的。

引用this

  

JAVA_HOME和java.home有什么区别?

     

JAVA_HOME是JDK安装目录,例如C:\ jdk5。它的意思是   设置为环境变量并在Windows批处理文件中引用   Unix脚本。我总是在Windows控制面板和.tcsh中使用它   文件以及其他常见环境变量。一些Java   应用程序使用名称jdk.home来实现此目的,我认为是这样   一个更好的名字。但是JAVA_HOME从一开始就被使用了   现在是一个惯例。

     

java.home是JRE安装目录,例如C:\ jdk5 \ jre,或   C:\ Program Files \ Java \ jre1.5.0_06。与JAVA_HOME不同,我从未见过   java.home作为环境变量。 java.home是一个内置的Java   system属性,其值为JRE安装目录。一切都好   您也可以将Java系统属性公开为Ant构建属性   也可以在构建文件中使用$ {java.home}。

     

jre.home会是一个更好的名字吗?也许,但我认为Sun不会   改变它。

你可以看到maven在mvn.bat上使用JAVA_HOME:

:endInit
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
..
%MAVEN_JAVA_EXE% %MAVEN_OPTS% -classpath %CLASSWORLDS_JAR% ..

如果你想确定,你可以在mvn.bat中注释掉“@echo off”语句,这样你就可以看到它正被使用。


TL; DR:根据您提供的信息,您的配置是正确的,无需更改任何内容。


编辑:多亏了这个帖子,还有an issue about this being confusing,这导致了Maven版本3.5.4的输出更改。

答案 1 :(得分:0)

帮助我调试mvn / jdk问题的是在运行mvn之前进行以下设置: set MAVEN_BATCH_ECHO=on

您将获得详细的输出(在Windows上),包括Maven如何选择Java的信息。