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 的人有所帮助。
我在 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 的人有所帮助。