首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在M1 Mac上使用夸克构建本机映像失败

在M1 Mac上使用夸克构建本机映像失败
EN

Stack Overflow用户
提问于 2021-06-22 19:31:54
回答 3查看 3.6K关注 0票数 4

在我的项目的根目录中,我发出了以下命令,以创建将特定于我的操作系统的本机可执行文件。有关详细信息,请参阅下列指南

代码语言:javascript
复制
mvn package -Pnative -Dquarkus.native.container-build=true

这是输出。

代码语言:javascript
复制
[INFO] Scanning for projects...
[INFO]
[INFO] ---------------------< com.example:quarkus-spring >---------------------
[INFO] Building quarkus-spring 1.0-SNAPSHOT
[INFO] --------------------------------[ jar ]---------------------------------
[INFO]
[INFO] --- quarkus-maven-plugin:1.13.7.Final:generate-code (default) @ quarkus-spring ---
[INFO]
[INFO] --- maven-resources-plugin:2.6:resources (default-resources) @ quarkus-spring ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 1 resource
[INFO]
[INFO] --- maven-compiler-plugin:3.8.1:compile (default-compile) @ quarkus-spring ---
[INFO] Nothing to compile - all classes are up to date
[INFO]
[INFO] --- quarkus-maven-plugin:1.13.7.Final:generate-code-tests (default) @ quarkus-spring ---
[INFO]
[INFO] --- maven-resources-plugin:2.6:testResources (default-testResources) @ quarkus-spring ---
[INFO] Using 'UTF-8' encoding to copy filtered resources.
[INFO] Copying 0 resource
[INFO]
[INFO] --- maven-compiler-plugin:3.8.1:testCompile (default-testCompile) @ quarkus-spring ---
[INFO] Nothing to compile - all classes are up to date
[INFO]
[INFO] --- maven-surefire-plugin:3.0.0-M5:test (default-test) @ quarkus-spring ---
[INFO]
[INFO] -------------------------------------------------------
[INFO]  T E S T S
[INFO] -------------------------------------------------------
[INFO] Running com.example.controller.GreetingControllerTest
2021-06-22 21:17:05,339 WARN  [io.qua.dat.dep.dev.DevServicesDatasourceProcessor] (build-10) Unable to determine a database type for default datasource
2021-06-22 21:17:05,340 WARN  [io.qua.agr.dep.AgroalProcessor] (build-16) The Agroal dependency is present but no JDBC datasources have been defined.
2021-06-22 21:17:06,080 INFO  [io.quarkus] (main) Quarkus 1.13.7.Final on JVM started in 1.004s. Listening on: http://localhost:8081
2021-06-22 21:17:06,081 INFO  [io.quarkus] (main) Profile test activated.
2021-06-22 21:17:06,081 INFO  [io.quarkus] (main) Installed features: [agroal, cdi, hibernate-orm, hibernate-orm-panache, mongodb-client, mutiny, narayana-jta, resteasy, smallrye-context-propagation, spring-boot-properties, spring-data-jpa, spring-data-rest, spring-di]
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0, Time elapsed: 1.755 s - in com.example.controller.GreetingControllerTest
2021-06-22 21:17:06,699 INFO  [io.quarkus] (main) Quarkus stopped in 0.020s
[INFO]
[INFO] Results:
[INFO]
[INFO] Tests run: 1, Failures: 0, Errors: 0, Skipped: 0
[INFO]
[INFO]
[INFO] --- maven-jar-plugin:2.4:jar (default-jar) @ quarkus-spring ---
[INFO]
[INFO] --- quarkus-maven-plugin:1.13.7.Final:build (default) @ quarkus-spring ---
[INFO] [org.jboss.threads] JBoss Threads version 3.2.0.Final
[WARNING] [io.quarkus.agroal.deployment.AgroalProcessor] The Agroal dependency is present but no JDBC datasources have been defined.
[INFO] [org.hibernate.Version] HHH000412: Hibernate ORM core version 5.4.29.Final
[INFO] [io.quarkus.deployment.pkg.steps.JarResultBuildStep] Building native image source jar: /Users/viswanath/projects/quarkus-spring/target/quarkus-spring-1.0-SNAPSHOT-native-image-source-jar/quarkus-spring-1.0-SNAPSHOT-runner.jar
[INFO] [io.quarkus.deployment.pkg.steps.NativeImageBuildStep] Building native image from /Users/viswanath/projects/quarkus-spring/target/quarkus-spring-1.0-SNAPSHOT-native-image-source-jar/quarkus-spring-1.0-SNAPSHOT-runner.jar
[INFO] [io.quarkus.deployment.pkg.steps.NativeImageBuildContainerRunner] Using docker to run the native image builder
[INFO] [io.quarkus.deployment.pkg.steps.NativeImageBuildContainerRunner] Checking image status quay.io/quarkus/ubi-quarkus-native-image:21.0-java11
21.0-java11: Pulling from quarkus/ubi-quarkus-native-image
Digest: sha256:356624049da5f564e14acbaf167a341a01b332569db83e9967b1e72cfdf06653
Status: Image is up to date for quay.io/quarkus/ubi-quarkus-native-image:21.0-java11
quay.io/quarkus/ubi-quarkus-native-image:21.0-java11
[INFO] [io.quarkus.deployment.pkg.steps.NativeImageBuildStep] Running Quarkus native-image plugin on GraalVM Version 21.0.0.2 (Java Version 11.0.10+8-jvmci-21.0-b06)
[INFO] [io.quarkus.deployment.pkg.steps.NativeImageBuildRunner] docker run --env LANG=C --rm -v /Users/viswanath/projects/quarkus-spring/target/quarkus-spring-1.0-SNAPSHOT-native-image-source-jar:/project:z quay.io/quarkus/ubi-quarkus-native-image:21.0-java11 -J-Djava.util.logging.manager=org.jboss.logmanager.LogManager -J-Dsun.nio.ch.maxUpdateArraySize=100 -J-DCoordinatorEnvironmentBean.transactionStatusManagerEnable=false -J-Dvertx.logger-delegate-factory-class-name=io.quarkus.vertx.core.runtime.VertxLogDelegateFactory -J-Dvertx.disableDnsResolver=true -J-Dio.netty.leakDetection.level=DISABLED -J-Dio.netty.allocator.maxOrder=1 -J-Duser.language=en -J-Duser.country=GB -J-Dfile.encoding=UTF-8 --initialize-at-build-time= -H:InitialCollectionPolicy=com.oracle.svm.core.genscavenge.CollectionPolicy\$BySpaceAndTime -H:+JNI -H:+AllowFoldMethods -jar quarkus-spring-1.0-SNAPSHOT-runner.jar -H:FallbackThreshold=0 -H:+ReportExceptionStackTraces -J-Xmx8192m -H:-AddAllCharsets -H:EnableURLProtocols=http,https --enable-all-security-services --no-server -H:-UseServiceLoaderFeature -H:+StackTrace quarkus-spring-1.0-SNAPSHOT-runner
WARNING: The requested image's platform (linux/amd64) does not match the detected host platform (linux/arm64/v8) and no specific platform was requested
^C%

本机映像生成失败,因为构建只挂起.

我选择在我的主机上安装Graal,并选择基于非容器的方法,如下所示。

  • 使用以下命令在M1 Mac上安装Graal ❯brew安装-/tap/graalvm lts-java11
  • 将Graal添加到JEnv托管版本的Java 添加/Library/Java/JavaVirtualMachines/graalvm-ce-lts-java11-20.3.1/Contents/Home graalvm64 64-11.0.10
  • 对于该项目,设置Graal的Java 11。 ❯jenv局部graalvm64 64-11.0.10
  • 将GRAALVM_HOME环境变量设置为GraalVM安装目录。将以下内容添加到~/..zshrc中 GRAALVM_HOME=/Library/Java/JavaVirtualMachines/graalvm-ce-lts-java11-20.3.1/Contents/Home出口❯

并通过发出命令重新加载对.zshrc所做的更改。

代码语言:javascript
复制
❯ source ~/.zshrc
  • 使用以下命令安装本机映像工具。GraalVM以前的一些版本默认包括本机映像工具。这种情况不再是这样;它必须作为安装GraalVM之后的第二步来安装。 GRAALVM_HOME${❯}/bin/gu安装本机映像
  • 安装binutils并将其添加到路径 ❯brew安装绑定 PATH=/opt/❯/opt/binutils/bin:$PATH“>> ~/..zshrc❯❯~/.
  • 使用项目根目录中的以下命令创建本机可执行文件 清洁安装-Pnative -D本机-Image.docker-❯=Try-Dquarkus.native.❯-xmx=4G

最后,当我运行本地映像时,它失败了。

代码语言:javascript
复制
❯ ~/projects/quarkus-spring/target ./quarkus-spring-1.0-SNAPSHOT-runner                                      
[1]    11638 killed     ./quarkus-spring-1.0-SNAPSHOT-runner

有什么帮助吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2021-06-23 20:34:05

文档解释说,-Dquarkus.native.container-build=true选项意味着您希望构建一个Linux可执行文件,并且构建应该在容器中进行。您甚至可以通过以下方式控制该Docker/Podman的运行时:

代码语言:javascript
复制
# Docker
./mvnw package -Pnative -Dquarkus.native.container-build=true -Dquarkus.native.container-runtime=docker
# Podman
./mvnw package -Pnative -Dquarkus.native.container-build=true -Dquarkus.native.container-runtime=podman

这很可能是上一个命令之后可执行文件在MacOS上不能工作的原因,因为它是一个Linux二进制文件。你可以用以下方法检查:

代码语言:javascript
复制
file ./quarkus-spring-1.0-SNAPSHOT-runner

虽然在命令行中使用的是"-Dquarkus.native.docker-build=true“,而不是”-Dquarkus.native.contain-build.true“,但我不知道是否有任何关联。

票数 3
EN

Stack Overflow用户

发布于 2022-05-24 14:30:11

这个另一个类似问题的答案也适用于我。。基本上,您只需要在您的M1笔记本上构建基本的graalvm映像,并使用-Dquarkus.native.builder-image=graalvm引用该图像(例如,这里的图像被标记为graalvm)

票数 0
EN

Stack Overflow用户

发布于 2022-07-02 13:59:27

如果您使用的是macOS Catalina,然后您可能需要从这些位中移除隔离属性,然后才能使用它们来执行此操作,请运行以下命令:

代码语言:javascript
复制
$ sudo xattr -r -d com.apple.quarantine path/to/graalvm/folder/

基于Graal提交:https://github.com/oracle/graal/tree/vm-22.1.0

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68089731

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档