Quarkus + Panache + RestEasy Native Image构建失败

时间:2020-06-08 21:22:06

标签: resteasy quarkus graalvm-native-image quarkus-panache

我有以下简化的设置:

1)

import javax.ws.rs.GET;
import javax.ws.rs.Path;

@Path("/api")
public class MyResource {

    public MyResource() {
    }

    @GET
    @Path("/myPath/")
    public void get() {
    }
}

2)

import io.quarkus.hibernate.orm.panache.PanacheEntity;
import javax.persistence.Entity;

@Entity
public class MyEntity extends PanacheEntity {

    public String hello;

    public MyEntity() {
        //For Panache only
    }
}

3)pom.xml:

[...]
    <properties>
            <compiler-plugin.version>3.8.1</compiler-plugin.version>
            <maven.compiler.source>11</maven.compiler.source>
            <maven.compiler.target>11</maven.compiler.target>
            <quarkus-plugin.version>1.5.0.Final</quarkus-plugin.version>
            <quarkus.platform.artifact-id>quarkus-universe-bom</quarkus.platform.artifact-id>
            <quarkus.platform.group-id>io.quarkus</quarkus.platform.group-id>
            <quarkus.platform.version>1.5.0.Final</quarkus.platform.version>
        </properties>
        <dependencyManagement>
            <dependencies>
                <dependency>
                    <groupId>${quarkus.platform.group-id}</groupId>
                    <artifactId>${quarkus.platform.artifact-id}</artifactId>
                    <version>${quarkus.platform.version}</version>
                    <type>pom</type>
                    <scope>import</scope>
                </dependency>
            </dependencies>
        </dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>io.quarkus</groupId>
                <artifactId>quarkus-hibernate-orm-panache</artifactId>
            </dependency>
            <dependency>
                <groupId>io.quarkus</groupId>
                <artifactId>quarkus-jdbc-mariadb</artifactId>
            </dependency>
            <dependency>
                <groupId>io.quarkus</groupId>
                <artifactId>quarkus-resteasy</artifactId>
            </dependency>
        </dependencies>
        <build>
            <plugins>
                <plugin>
                    <groupId>io.quarkus</groupId>
                    <artifactId>quarkus-maven-plugin</artifactId>
                    <version>${quarkus-plugin.version}</version>
                    <executions>
                        <execution>
                            <goals>
                                <goal>build</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
        <profiles>
            <profile>
                <id>native</id>
                <activation>
                    <property>
                        <name>native</name>
                    </property>
                </activation>
                <build/>
                <properties>
                    <quarkus.package.type>native</quarkus.package.type>
                </properties>
            </profile>
        </profiles>
    </project>

4)application.properties

quarkus.datasource.db-kind = mariadb
quarkus.datasource.username = admin
quarkus.datasource.password = admin
quarkus.datasource.jdbc.url = jdbc:mariadb://localhost:5432/mydatabase
quarkus.hibernate-orm.database.generation = drop-and-create

当我使用本机Maven配置文件(mvn clean package -Pnative)运行此文件时,我得到:

Fatal error: com.oracle.graal.pointsto.util.AnalysisError$ParsingError: Error encountered while parsing com.oracle.svm.reflect.Class_getNestHost_d0409f1154f6242e625526eadd05fbcd60e7d7e9.invoke(java.lang.Object, java.lang.Object[]) 
Parsing context:
        parsing java.lang.reflect.Method.invoke(Method.java:566)
        parsing javax.enterprise.util.AnnotationLiteral.invoke(AnnotationLiteral.java:288)
        parsing javax.enterprise.util.AnnotationLiteral.getMemberValue(AnnotationLiteral.java:276)
        parsing javax.enterprise.util.AnnotationLiteral.hashCode(AnnotationLiteral.java:246)
        parsing org.graalvm.collections.EconomicMapImpl.getHashIndex(EconomicMapImpl.java:414)
[...]
Caused by: com.oracle.svm.hosted.substitute.DeletedElementException: Unsupported method java.lang.Class.getNestHost() is reachable: The declaring class of this element has been substituted, but this element is not present in the substitution class
[...]
To diagnose the issue, you can add the option --report-unsupported-elements-at-runtime. 

在运行时使用--report-unsupported-elements-run来运行它也没有太大帮助。 当我删除MyEntity类时,它会在Mac +上成功编译为本地可执行文件 Graalvm-ce-java11-20.0.0

有什么想法吗?

1 个答案:

答案 0 :(得分:2)

我更新到20.0.0,一切正常。我只是找到了一种解决该错误的方法,那就是如果您忽略了正确设置GraalVM的方法。我的Mac中的环境变量是:

export GRAALVM_HOME=/Library/Java/JavaVirtualMachines/graalvm-ce-java11-20.0.0/Contents/Home
export JAVA_HOME=${GRAALVM_HOME}
export PATH=${GRAALVM_HOME}/bin:$PATH

让我知道这是否对您有用。