gpt4 book ai didi

java - jlink 打包当前平台的二进制文件

转载 作者:行者123 更新时间:2023-12-05 06:51:46 28 4
gpt4 key购买 nike

我正在尝试为使用 Java 11 构建并使用 jlink 打包的应用程序构建跨平台存档。

对于跨平台打包,我的构建基于 this answer .我已经设法让我的 Gradle 构建下载目标平台的 JDK 并使用适当的 jmods 文件夹调用 jlink,但是目标图像总是包含主机的二进制文件和 JRE 结构平台(在我的例子中是 Windows,这意味着生成的 bin 文件夹总是包含 DLL 和 Windows 可执行文件)。如果我提供 --strip-native-commands 标志,则根本不包含任何可执行文件,尽管 DLL 仍然包含在内。

有没有办法让jlink打包正确的JRE文件?

主机 JDK: Windows Oracle JDK 11.0.10 x64

目标 JDK: OpenJDK 11.0.2 x64

示例 Linux 调用:

C:\Program Files\Java\jdk-11.0.10/bin/jlink.exe
--module-path C:\projectdir\build\install\project-linux\lib;C:\projectdir\build\JREs\linux\jmods
--add-modules com.acme.app
--compress 2
--launcher app=com.acme.app/com.acme.app.Main
--no-header-files
--no-man-pages
--strip-debug
--dedup-legal-notices=error-if-not-same-content
--output C:\projectdir\build\packageFiles\linux

GraalVM

使用 GraalVM CE Java 11 21.0.0 产生:

java.io.IOException: Invalid JMOD file: C:\jdks\graalvm-ce-java11-21.0.0\jmods\java.base.jmod

这使得 GraalVM 的 jlink 看起来总是尝试使用主机的 JMOD 文件。

OpenJDK

使用 OpenJDK 11.0.2 x64 会产生相同的结果,即在创建的运行时镜像中包含主机的二进制文件。 Zulu OpenJDK 11.0.10+9 x64 的行为相同。

最佳答案

发现问题:问题出在我对 Linux 和 MacOS JDK 发行版的 jmods 目录的引用上。

对于 Linux,我错误地将build设置为下载版本 11.0.1 而不是 11.0.2,这最终导致了扁平化层次结构的逻辑,而不是压平它。这意味着 build/JREs/linux/jmods 引用没有针对任何现有文件夹,这意味着 jlink 没有在那里找到 JDK 模块,因此主机文件是包括在内。

MacOS JDK 具有完全不同的文件结构,因此扁平化逻辑是错误的。最终,这会导致相同的 jmods 文件夹丢失症状。

修复了这两个问题后,jlink 工具现在可以在构建跨平台运行时镜像时正确打包目标 JDK 的文件。

关于java - jlink 打包当前平台的二进制文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66083431/

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com