如何检查在 Gradle 构建过程中使用了哪个已安装的 JDK

Mir*_*ili 8 java version gradle gradlew

这是我的输出gradle -v(在使用包装器的项目中):

$ ./gradlew -v

------------------------------------------------------------
Gradle 5.0
------------------------------------------------------------

Build time:   2018-11-26 11:48:43 UTC
Revision:     7fc6e5abf2fc5fe0824aec8a0f5462664dbcd987

Kotlin DSL:   1.0.4
Kotlin:       1.3.10
Groovy:       2.5.4
Ant:          Apache Ant(TM) version 1.9.13 compiled on July 10 2018
JVM:          11.0.1 (Oracle Corporation 11.0.1+13-LTS)
OS:           Linux 3.10.0-862.11.6.el7.x86_64 amd64
Run Code Online (Sandbox Code Playgroud)

尤其是看到这一行:

JVM: 11.0.1 (Oracle Corporation 11.0.1+13-LTS)
Run Code Online (Sandbox Code Playgroud)

我想切换到 OpenJDK 11。所以选择它,如下所示:

# alternatives --config java

There are 4 programs which provide 'java'.

  Selection    Command
-----------------------------------------------
*  1           /usr/java/jdk-11.0.1/bin/java
 + 2           /usr/local/jdk-11.0.1/bin/java
   3           /usr/java/jre1.8.0_191-i586/bin/java
   4           /usr/java/jdk1.8.0_191-amd64/jre/bin/java

Enter to keep the current selection[+], or type selection number: 2

# java -version
openjdk version "11.0.1" 2018-10-16
OpenJDK Runtime Environment 18.9 (build 11.0.1+13)
OpenJDK 64-Bit Server VM 18.9 (build 11.0.1+13, mixed mode)
Run Code Online (Sandbox Code Playgroud)

但是gradle -v输出没有区别。所以我在网上搜索并找到了一些方法(见这里):

  1. 编辑gradle.properties文件

  2. 使用-Dorg.gradle.java.home命令行选项

  3. 编辑build.gradle文件

我使用了前两种方式。两者都有效(为了测试我切换到JDK 8然后运行build任务。由于我的代码中的一些新功能不受 Java 8 支持,任务失败)。但结果gradle -v依旧没变!即使使用第二种方式:

# ./gradlew -Dorg.gradle.java.home=/usr/java/jdk1.8.0_191-amd64 -v

------------------------------------------------------------
Gradle 5.0
------------------------------------------------------------

Build time:   2018-11-26 11:48:43 UTC
Revision:     7fc6e5abf2fc5fe0824aec8a0f5462664dbcd987

Kotlin DSL:   1.0.4
Kotlin:       1.3.10
Groovy:       2.5.4
Ant:          Apache Ant(TM) version 1.9.13 compiled on July 10 2018
JVM:          11.0.1 (Oracle Corporation 11.0.1+13-LTS)
OS:           Linux 3.10.0-862.11.6.el7.x86_64 amd64
Run Code Online (Sandbox Code Playgroud)

那么问题来了,如何查看Gradle在build处理过程中使用的是哪个JDK版本呢?

mad*_*ead 8

您可以添加一个任务,在执行时打印您需要的内容(Kotlin DSL):

tasks {
    val j by creating {
        doLast {
            println(System.getProperty("java.home"))
        }
    }
}
Run Code Online (Sandbox Code Playgroud)

常规 DSL:

tasks.register("j") {
    doLast {
        println System.getProperty("java.home")           
    }
}
Run Code Online (Sandbox Code Playgroud)

然后执行./gradlew j

/usr/lib/jvm/java-8-openjdk/jre
Run Code Online (Sandbox Code Playgroud)

为什么可以gradlew使用另一个JVM?看看这个脚本,你会看到它使用JAVA_HOME变量来搜索 JVM。所以可能你的版本PATH不一样,那JAVA_HOME就是指向。


Mir*_*ili 7

我找到了一种替代方法(@madhead 答案除外),仅适用于使用 Gradle 守护进程时

首先,PID通过运行找到守护进程gradlew --status(请参阅此处了解更多信息)。示例输出:

   PID STATUS   INFO
 11432 IDLE     5.0

Only Daemons for the current Gradle version are displayed. See https://docs.gradle.org/5.0/userguide/gradle_daemon.html#sec:status
Run Code Online (Sandbox Code Playgroud)

然后使用PID来查找JDK使用的是哪个:

ll /proc/<PID>/exe
Run Code Online (Sandbox Code Playgroud)

示例输出:

lrwxrwxrwx. 1 0xy 0xy 0 Jan  5 04:03 /proc/11432/exe -> /usr/local/jdk-11.0.1/bin/java
Run Code Online (Sandbox Code Playgroud)

在 Windows 上:

> wmic process where "processId=<PID>" get Name, ProcessID, ExecutablePath
Run Code Online (Sandbox Code Playgroud)

示例输出:

ExecutablePath                                     Name      ProcessId
C:\Program Files\Java\openjdk-11.0.1\bin\java.exe  java.exe  11432 
Run Code Online (Sandbox Code Playgroud)