Gradle — 新创建的守护进程具有与预期不同的上下文

Gradle — The newly created daemon process has a different context than expected

我在 Ubuntu (Linux uplink 4.13.0-32-generic #35~16.04.1-Ubuntu SMP Thu Jan 25 10:13:43 UTC 2018 x86_64 x86_64 x86_64 GNU/Linux) 中通过 Nix 安装了 OpenJDK。

gorre@uplink:~$ java -version
openjdk version "1.8.0_172"
OpenJDK Runtime Environment (build 1.8.0_172-02)
OpenJDK 64-Bit Server VM (build 25.172-b02, mixed mode)

gorre@uplink:~$ which java
/home/gorre/.nix-profile/bin/java

gorre@uplink:/nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02$ ll
total 24K
dr-xr-xr-x 3 gorre 4.0K Dec 31  1969 share/
dr-xr-xr-x 2 gorre 4.0K Dec 31  1969 nix-support/
dr-xr-xr-x 3 gorre 4.0K Dec 31  1969 lib/
lrwxrwxrwx 1 gorre   80 Dec 31  1969 jre -> /nix/store/n7rh8v269qb1fs6314yq0wg7q8cajw0g-openjdk-8u172b02-jre/lib/openjdk/jre/
dr-xr-xr-x 2 gorre 4.0K Dec 31  1969 include/
lrwxrwxrwx 1 gorre   76 Dec 31  1969 bin -> /nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02/lib/openjdk/bin/

现在,当我尝试 build/run 在 IntelliJ IDEA 2017.3.4 (Ultimate Edition) Build #IU-173.4548.28 中使用 Gradle 4.4 的项目时,我收到此错误:

The newly created daemon process has a different context than expected.
It won't be possible to reconnect to this daemon. Context mismatch: 
Java home is different.
Wanted: DefaultDaemonContext[uid=null,javaHome=/nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02,daemonRegistryDir=/home/gorre/.gradle/daemon,pid=12824,idleTimeout=null,daemonOpts=-XX:+HeapDumpOnOutOfMemoryError,-Xmx1024m,-Dfile.encoding=UTF-8,-Duser.country=US,-Duser.language=en,-Duser.variant]
Actual: DefaultDaemonContext[uid=b813ba02-e4a6-4bfe-91b2-8ed32963f7cc,javaHome=/nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02/lib/openjdk,daemonRegistryDir=/home/gorre/.gradle/daemon,pid=14245,idleTimeout=10800000,daemonOpts=-XX:+HeapDumpOnOutOfMemoryError,-Xmx1024m,-Dfile.encoding=UTF-8,-Duser.country=US,-Duser.language=en,-Duser.variant]

我到处搜索,但其他 answers/solutions 不起作用,甚至没有在 gradle.properties 中指定 Java 家(在项目内部或我用户的家中):

org.gradle.java.home = /nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02

另一方面,如果我 build/run 终端上的项目工作正常。有什么线索吗?


更新#1

这是我对 Gradle 和 IntelliJ IDEA 中的 SDK 的配置:

检查 Gradle 守护程序的 Idea 设置:

Build, Execution, Deployment -> Build Tools -> Gradle.

有一个选项"Gradle JVM"。看起来 Idea 使用 Java 9 或其他一些 non-compatible JVM 到 运行 Gradle。 Yoy 应该 select 你来自 Nix 的 Java 版本。

我想通了,尽管它就在我眼前 — 我没有仔细阅读错误消息。

基本上,Nix 设置的 default Java 主页位于:/nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02/lib/openjdk 而我在 IntelliJ IDEA 中手动设置的主页位于:/nix/store/f9053w1lfrkhgqfpr6l82ssxmjpsni1j-openjdk-8u172b02(注意缺少 ../lib/openjdk 段)。

在 IntelliJ IDEA 中更正后一切正常。我不需要任何其他 and/or 特别的东西。

我希望这对以后的其他人或任何其他 fast-reader Nix 的人有所帮助。