不,这没有错。它指向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需要工具.jar),但maven实际上使用JDK中的jre来运行自己。
使用时,maven 使用 java 内部 java.home 属性,从源代码中可以看出:mvn -version
version.append( "Java home: " + System.getProperty( "java.home", "<unknown java home>" ) ).append( LS );
此属性与JAVA_HOME环境设置不同,因此它可能会欺骗您。它实际上是动态属性,显示哪个 JRE 正在运行您的代码。如果您编译并执行一个测试.java测试类打印相同,您可以看到,如果你的JAVA_HOME指向一个JDK,java.home的值不等于你的JAVA_HOME。这是预料之中的。
引用这个:
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 系统属性,其值为 JRE 安装目录。由于所有 Java 系统属性也公开为 Ant 构建属性,因此您也可以在构建文件中使用 ${java.home}。
jre.home会是一个更好的名字吗?也许吧,但我不认为Sun会改变它。
您可以看到 maven 在 mvn 上使用JAVA_HOME.bat:
:endInit
SET MAVEN_JAVA_EXE="%JAVA_HOME%\bin\java.exe"
..
%MAVEN_JAVA_EXE% %MAVEN_OPTS% -classpath %CLASSWORLDS_JAR% ..
如果你想确保,你可以在mvn.bat中注释掉“@echo关闭”语句,这样你可以看到它正在被使用。
TL;DR:根据您提供的信息,您的配置是正确的,无需更改任何内容。
编辑:多亏了这个线程,还有一个关于这个令人困惑的问题,这导致Maven版本3.5.4的输出发生了变化。