【发布时间】:2020-12-26 23:59:16
【问题描述】:
使用 Java 11.0.9 (GraalVM CE 20.3.0) 和 Micronaut 2.2.1 应用程序,使用 Firebase 管理员 7.1.0,当我根据Micronaut documentation将我的应用程序打包为原生镜像时,出现以下错误:
$ ./gradlew nativeImage
> Task :nativeImage
[application:15026] classlist: 4,054.46 ms, 1.19 GB
[application:15026] (cap): 504.32 ms, 1.19 GB
[application:15026] setup: 1,827.02 ms, 1.19 GB
To see how the classes got initialized, use --trace-class-initialization=org.conscrypt.Conscrypt,org.conscrypt.OpenSSLProvider
[application:15026] analysis: 29,787.52 ms, 3.90 GB
Error: Classes that should be initialized at run time got initialized during image building:
org.conscrypt.Conscrypt was unintentionally initialized at build time. To see why org.conscrypt.Conscrypt got initialized use --trace-class-initialization=org.conscrypt.Conscrypt
org.conscrypt.OpenSSLProvider was unintentionally initialized at build time. To see why org.conscrypt.OpenSSLProvider got initialized use --trace-class-initialization=org.conscrypt.OpenSSLProvider
Error: Use -H:+ReportExceptionStackTraces to print stacktrace of underlying exception
Error: Image build request failed with exit status 1
> Task :nativeImage FAILED
FAILURE: Build failed with an exception.
问题是由包org.conscrypt 中的类引起的。相关的依赖来自
com.google.cloud:google-cloud-firestore:1.35.0 获取 org.conscrypt:conscrypt-openjdk-uber:2.2.1。
我对 GraalVM 非常陌生,而且远不了解导致此类问题的原因。但是,我注意到应该可以将一些参数传递给native-image,例如--initialize-at-build-time。
我的问题是如何解决这个问题?是否有要创建的配置文件以及 Micronaut 从选项中读取以转发到 native-image 可执行文件?
【问题讨论】:
标签: java google-cloud-firestore micronaut graalvm graalvm-native-image