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

时间:2018-12-13 12:09:10

标签: java gradle version 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

尤其要看这一行:

JVM: 11.0.1 (Oracle Corporation 11.0.1+13-LTS)

我希望切换到OpenJDK11。因此请选择它,如下所示:

# 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)

但是gradle -v的输出没有区别。因此,我在网上搜索并找到了一些方法(请参见here):

  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

所以问题是如何检查build过程中Gradle使用了哪个JDK版本?

2 个答案:

答案 0 :(得分:1)

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

tasks {
    val j by creating {
        doLast {
            println(System.getProperty("java.home"))
        }
    }
}

Groovy DSL:

tasks.register("j") {
    doLast {
        println System.getProperty("java.home")           
    }
}

然后执行./gradlew j

/usr/lib/jvm/java-8-openjdk/jre

为什么gradlew使用另一个JVM?看一下此脚本,您将看到它使用JAVA_HOME变量搜索JVM。因此,您的PATH指向的版本可能与JAVA_HOME指向的版本不同。

答案 1 :(得分:0)

我找到了另一种方法(@madhead answer除外)仅当您使用Gradle守护程序时

首先,通过运行PID查找守护程序的gradlew --status(有关更多信息,请参见here)。样本输出:

   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

然后使用PID查找使用了哪个JDK

ll /proc/<PID>/exe

示例输出:

lrwxrwxrwx. 1 0xy 0xy 0 Jan  5 04:03 /proc/11432/exe -> /usr/local/jdk-11.0.1/bin/java

在Windows上:

> wmic process where "processId=<PID>" get Name, ProcessID, ExecutablePath

示例输出:

ExecutablePath                                     Name      ProcessId
C:\Program Files\Java\openjdk-11.0.1\bin\java.exe  java.exe  11432