【问题标题】:Gradle jpackage creating unrunnable applicationGradle jpackage 创建无法运行的应用程序
【发布时间】:2021-06-05 15:12:28
【问题描述】:

我正在尝试使用简单的 Gradle JavaFX 应用程序运行 jpackage,主要是为了尝试一下。它没有什么特别之处,它是添加了 Gradle 的 IntelliJ JavaFX 示例。该应用程序在 gradlew clean build run 下运行良好。但是,当使用 gradlew jpackage 创建包时,生成的 exe 会立即崩溃并创建一个 hs_err_pid。

# A fatal error has been detected by the Java Runtime Environment:
#
#  EXCEPTION_ACCESS_VIOLATION (0xc0000005) at pc=0x0000000000000000, pid=1132, tid=15340
#
# JRE version:  (15.0.2+10) (build )
# Java VM: OpenJDK 64-Bit Server VM (15.0.2+10, mixed mode, tiered, compressed oops, g1 gc, windows-amd64)
# Problematic frame:
# C  0x0000000000000000

在此处查看完整输出:https://pastebin.com/LgbSFa5L

我在similar question 上尝试过答案,但没有奏效。

  • zip.dll{app}\runtime\bin 复制到{app}\
  • 尝试其他 JDK
    • 采用OpenJDK 11
    • 采用OpenJDK 14
    • 采用OpenJDK 15
    • BellSoft Liberica JDK 15

build.gradle 看起来像这样

// Setup Gradle
plugins {
    id "application"
    id "org.beryx.runtime" version "1.12.2"
    id "org.openjfx.javafxplugin" version '0.0.9'
}

repositories {
    mavenCentral()
    jcenter()
}

// Setup application, dependencies
group = "io.mattw.sample"
sourceCompatibility = 15
targetCompatibility = 15

application {
    mainClassName = "io.mattw.sample.Main"
}

javafx {
    version = 15
    modules = ["javafx.base", "javafx.controls", "javafx.fxml"]
}

dependencies {

}

// Setup release
// https://simply-how.com/custom-java-runtime
runtime {
    addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
}

tasks.runtime.doLast {
    copy {
        from("src/main/resources")
        into("$buildDir/image/bin")
    }
}

编辑:

使用WinDbg (preview) 运行exe 时,我得到以下输出。可能与我正常安装 Java 8 有关,但我希望它使用捆绑的 SDK 而不是系统。

Microsoft (R) Windows Debugger Version 10.0.21306.1007 AMD64
Copyright (c) Microsoft Corporation. All rights reserved.

CommandLine: C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\gradle-test-javafx.exe

************* Path validation summary **************
Response                         Time (ms)     Location
Deferred                                       srv*
Symbol search path is: srv*
Executable search path is: 
ModLoad: 00007ff6`995d0000 00007ff6`9963f000   image00007ff6`995d0000
ModLoad: 00007ffc`36450000 00007ffc`36646000   ntdll.dll
ModLoad: 00007ffc`35320000 00007ffc`353dd000   C:\WINDOWS\System32\KERNEL32.DLL
ModLoad: 00007ffc`33d90000 00007ffc`34059000   C:\WINDOWS\System32\KERNELBASE.dll
ModLoad: 00007ffc`36210000 00007ffc`363b0000   C:\WINDOWS\System32\USER32.dll
ModLoad: 00007ffc`33d30000 00007ffc`33d52000   C:\WINDOWS\System32\win32u.dll
ModLoad: 00007ffc`346f0000 00007ffc`3471a000   C:\WINDOWS\System32\GDI32.dll
ModLoad: 00007ffc`343a0000 00007ffc`344ab000   C:\WINDOWS\System32\gdi32full.dll
ModLoad: 00007ffc`33c90000 00007ffc`33d2d000   C:\WINDOWS\System32\msvcp_win.dll
ModLoad: 00007ffc`33b90000 00007ffc`33c90000   C:\WINDOWS\System32\ucrtbase.dll
ModLoad: 00007ffc`35ac0000 00007ffc`36202000   C:\WINDOWS\System32\SHELL32.dll
(4ad0.33e0): Break instruction exception - code 80000003 (first chance)
ntdll!LdrpDoDebuggerBreak+0x30:
00007ffc`36520670 cc              int     3
0:000> g
ModLoad: 00007ffc`355c0000 00007ffc`355f0000   C:\WINDOWS\System32\IMM32.DLL
ModLoad: 00007ffc`34ba0000 00007ffc`34c4e000   C:\WINDOWS\System32\shcore.dll
ModLoad: 00007ffc`35a20000 00007ffc`35abe000   C:\WINDOWS\System32\msvcrt.dll
ModLoad: 00007ffc`34840000 00007ffc`34b96000   C:\WINDOWS\System32\combase.dll
ModLoad: 00007ffc`35720000 00007ffc`3584b000   C:\WINDOWS\System32\RPCRT4.dll
ModLoad: 00007ffc`11d50000 00007ffc`11d68000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jli.dll
ModLoad: 00007ffc`224e0000 00007ffc`22590000   C:\WINDOWS\WinSxS\amd64_microsoft.windows.common-controls_6595b64144ccf1df_5.82.19041.488_none_4238de57f6b64d28\COMCTL32.dll
ModLoad: 00007ffc`22cb0000 00007ffc`22cc9000   C:\WINDOWS\SYSTEM32\VCRUNTIME140.dll
ModLoad: 00007ffc`34c50000 00007ffc`34cfc000   C:\WINDOWS\System32\ADVAPI32.dll
ModLoad: 00007ffc`35520000 00007ffc`355bc000   C:\WINDOWS\System32\sechost.dll
ModLoad: 00007ffc`10080000 00007ffc`10095000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\vcruntime140.dll
ModLoad: 00007ffb`f76b0000 00007ffb`f774b000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\msvcp140.dll
ModLoad: 00007ffb`a5030000 00007ffb`a5bbf000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\server\jvm.dll
ModLoad: 00007ffc`34630000 00007ffc`34638000   C:\WINDOWS\System32\PSAPI.DLL
ModLoad: 00007ffc`1ff10000 00007ffc`1ff19000   C:\WINDOWS\SYSTEM32\WSOCK32.dll
ModLoad: 00007ffc`32a70000 00007ffc`32a7a000   C:\WINDOWS\SYSTEM32\VERSION.dll
ModLoad: 00007ffc`261f0000 00007ffc`26217000   C:\WINDOWS\SYSTEM32\WINMM.dll
ModLoad: 00007ffc`35870000 00007ffc`358db000   C:\WINDOWS\System32\WS2_32.dll
ModLoad: 0000014c`22330000 0000014c`2239b000   C:\WINDOWS\System32\ws2_32.DLL
ModLoad: 00007ffc`32a30000 00007ffc`32a42000   C:\WINDOWS\SYSTEM32\kernel.appcore.dll
ModLoad: 00007ffc`2acf0000 00007ffc`2acfa000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jimage.dll
ModLoad: 00007ffc`22590000 00007ffc`22774000   C:\WINDOWS\SYSTEM32\DBGHELP.DLL
ModLoad: 00007ffc`21be0000 00007ffc`21c0c000   C:\WINDOWS\SYSTEM32\dbgcore.DLL
ModLoad: 00007ffc`34060000 00007ffc`340e0000   C:\WINDOWS\System32\bcryptPrimitives.dll
ModLoad: 00007ffc`09f50000 00007ffc`09f75000   C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\java.dll
(4ad0.30c4): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
0000014c`23890969 8b06            mov     eax,dword ptr [rsi] ds:00000000`00000000=????????
0:004> g
(4ad0.30c4): Access violation - code c0000005 (first chance)
First chance exceptions are reported before any exception handling.
This exception may be expected and handled.
*** WARNING: Unable to verify checksum for C:\GitHub\gradle-test-javafx\build\jpackage\gradle-test-javafx\runtime\bin\jimage.dll
00000000`00000000 ??              ???
0:004> g
ntdll!NtTerminateProcess+0x14:
00007ffc`364ecba4 c3              ret

【问题讨论】:

  • 您能否尝试使用生成的运行时映像手动运行应用程序? .\build\jpackage\{app}\runtime\bin\java.exe -cp .\build\jpackage\{app}\app\{app}.jar io.mattw.sample.Main 问题可能出在 .exe 启动器中,在这种情况下,可能是您使用的 wixtoolset 版本有问题。
  • 似乎遇到了无法找到或加载主类的错误。尝试将"--main-class io.mattw.sample.Main" 添加到runtime { addOptions() } 列表中,现在gradlew jpackage --info 命令出错,它找不到导出多个javafx 模块的模块。我不是想创建一个模块化应用程序,只是一个带有捆绑运行时的简单 javafx 应用程序。我安装的 WiX 工具集似乎是 3.11.2.4516。
  • “错误,它找不到导出多个 javafx 模块的模块”我不确定你的意思,但 AFAIK javafx 模块必须放在模块路径上,因为你的应用程序是非模块化的,您可能缺少所需的 --add-modules 指令(虽然不确定 Liberica 是如何处理的)。如果您也可以在问题正文中包含错误,那将很有用。
  • 似乎添加 --main-class 选项无效,Error: unknown option: --main-class io.mattw.sample.Main 并删除它会使 jpackage 再次工作。我将包含尝试手动运行运行时映像的错误。
  • 找不到主类因为好像找不到javafx。但是,在 jpackage/{app}/app 文件夹中,我看到了 javafx 基础、控件、fxml jar

标签: java gradle javafx java-11 jpackage


【解决方案1】:

使用 Liberica,我可以通过添加以下行使其工作:

runtime {
    addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
    addModules("javafx.base", "javafx.controls", "javafx.fxml") // <----
}

否则,javafx.controls 模块似乎没有添加到生成的运行时映像中(您可以使用runtime\bin\java.exe --list-modules 进行检查)。

手动运行应用程序,然后通过生成的 exe 运行。


没有 Liberica,我可以通过将 --win-console 选项添加到 jpackage 来获得更多信息,如下所示:

runtime {
    addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")

    jpackage {
        imageOptions = ["--win-console"] // <---
    }
}

运行生成的exe结果

Error: JavaFX runtime components are missing, and are required to run this application

我认为 javafx 模块没有放在模块路径上,而是放在类路径上(现在不支持 AFAIK)是一个问题。这似乎是正在使用的运行时插件的问题(表示它不支持模块化应用程序)。

我可以通过添加手动使其工作

runtime {
    ...
    launcher {
        jvmArgs = ["--add-modules=javafx.base,javafx.controls,javafx.fxml"]
    }
}

然后手动将 javafx jar 复制到 app\mods 文件夹(我必须创建)。查看生成的{app}.cfg 文件 jpackage 创建,这就是启动器将用作模块路径的内容。我还从 {app}.cfg 文件中删除了 javafx jar 中不需要的 app.classpath 条目。

【讨论】:

  • 即使使用 Liberica 并添加该行,它似乎仍然对我不起作用。尝试运行生成的 exe 时相同的 EXCEPTION_ACCESS_VIOLATION。
  • 我遇到了别的东西,奇怪的是它似乎工作但并不理想。将{app}\runtime\bin中的所有内容复制到`{app}`中,然后运行exe即可。
  • 啊,好的,很高兴知道。尝试将其缩小到特定的所需文件可能会很好(我认为这是它需要的部分/全部 .dll 文件)。您也应该发布答案。
  • 看来把文件{app}\runtime\bin\zip.dll复制到{app}\zip.dllstackoverflow.com/a/65980258/5308944就够了
  • 是的,我用调试器查看了它,它从我机器上 PATH 上的另一个 JDK 加载 zip.dll,而不是从捆绑的运行时映像。清除路径会使应用程序崩溃。看起来该特定错误已由以下人员修复:bugs.openjdk.java.net/browse/…(在 16 中)
【解决方案2】:

这是一个 JDK15 错误。使用来自 JDK16 的 JPackage 为我解决了这个问题。

【讨论】:

  • 是的,正如@Jorn 已经指出的那样,它在此处被跟踪:bugs.openjdk.java.net/browse/JDK-8254920 并在 16 中修复
  • 想试试,但 Gradle 还不支持 JDK16
  • @MatthewWright 您可以通过使用新的工具链功能 (docs.gradle.org/6.8.3/userguide/toolchains.html) 来使用 JDK 16 及更高版本 基本上您在 JDK 15 上运行 Gradle,但使用 JDK 16 来编译和运行您的代码。 (虽然 JDK 16 目前存在一个错误,但有一个简单的解决方法:github.com/gradle/gradle/issues/15538
  • @MatthewWright 你可以通过命令行运行 JPackage,我就是这么做的。
  • 使用 beryx jlink 插件使用 JDK 15.0.1 创建运行时,然后使用该运行时从命令行使用 JDK 16 中的 jpackager 似乎是我发现的奇怪的解决方法让这个工作。希望 Gradle 能尽快支持 JDK16。
【解决方案3】:

结合这两个答案并稍等片刻更新为我解决了这个问题。

  1. 将 Gradle 升级到 7.0-RC-1,在 gradle-wrapper.properties 中支持 JDK 16
distributionUrl=https\://services.gradle.org/distributions/gradle-7.0-rc-1-bin.zip
  1. 已下载并使用 Liberica JDK 16 (@FlickIt)
  2. 在 build.gradle (@Jorn Vernee) 中对 Liberica 使用 addModules() 修复
runtime {
    addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
    addModules("javafx.base", "javafx.controls", "javafx.fxml", "javafx.graphics", "javafx.web")
}

在 Gradle 中运行 jpackage 现在会生成可运行的 JavaFX exe,而无需复制 dll!

如果您的应用程序不仅有 JavaFX 作为依赖项,请将 #3 更改为 ALL-MODULE-PATH。它使打包的文件/应用程序更大,但允许它运行。

runtime {
    addOptions("--strip-debug", "--compress", "2", "--no-header-files", "--no-man-pages")
    addModules("ALL-MODULE-PATH")
}

【讨论】:

  • 这适用于我的准系统示例,但是当尝试使用它迁移我现有的 JavaFX 项目之一时,它不起作用。尝试使用 .\runtime\bin\java.exe -cp .\app\{app}.jar {main-class} 手动运行时,我收到以下错误消息 Missing JavaFX application class {main-class}
  • 这似乎是由于额外的依赖关系,当将#3 更改为addModules("ALL-MODULE-PATH") 时,生成的文件要大得多,但应用程序可以运行。
猜你喜欢
  • 1970-01-01
  • 1970-01-01
  • 2020-08-01
  • 2020-04-04
  • 2022-06-21
  • 2018-11-06
  • 1970-01-01
  • 2016-06-06
相关资源
最近更新 更多