Quarkus 原生可执行构建:高内存消耗

Quarkus native executable build: high memory consumption

我正在按照 Quarkus - Building a Native Executable

中所述的多阶段 Docker 构建来构建 Quarkus 本机可执行文件

我的项目只包括 Hello World-Example 和一些添加的 ORM 功能(所以不是很多依赖项)。构建工作正常,但我的问题是,它在构建期间消耗了大量内存。这意味着最多 6 GiB。我认为构建时间也很长(总共约 4-6 分钟)。

当我在 CI/CD-infrastructure 上构建时,问题就开始了。我们那里没有那么多内存,因此构建失败 Error: Image build request failed with exit status 137.

我是做错了什么还是这是正常现象?有没有可能至少减少内存消耗?

感谢 Ken 和 Luca Burgazzoli!因此,GraalVM 使用 >4GiB 的 RAM 并花费超过 3 分钟是正常的。

可以通过将 -J-Xmx2G 指定为 quarkus-maven-pluginadditionalBuildArgs 参数来限制内存消耗。但这可能会增加构建时间。

@ben 的回答是正确的,但也许更精确一些会有用。您必须编辑 getting-started 目录中的 pom.xml 并编辑 native profile 并像这样添加 <additionalBuildArgs>-J-Xmx2G</additionalBuildArgs>

  <profile>
        <id>native</id>
        <activation>
            <property>
                <name>native</name>
            </property>
        </activation>
        <build>
            <plugins>
                <plugin>
                    <groupId>io.quarkus</groupId>
                    <artifactId>quarkus-maven-plugin</artifactId>
                    <version>${quarkus.version}</version>
                    <executions>
                        <execution>
                            <goals>
                                <goal>native-image</goal>
                            </goals>
                            <configuration>
                                <enableHttpUrlHandler>true</enableHttpUrlHandler>
                <additionalBuildArgs>-J-Xmx2G</additionalBuildArgs>
                            </configuration>
                        </execution>
                    </executions>
                </plugin>
                <plugin>
                    <artifactId>maven-failsafe-plugin</artifactId>
                     ...
                </plugin>
            </plugins>
        </build>
    </profile>

如果您使用的是 gradle,请像这样编辑 build.gradle

.
.
.

compileJava {
    options.compilerArgs << '-parameters'
}

buildNative {
   additionalBuildArgs = [
           '-J-Xmx2G'
   ]
}

因此您可以在使用 gradle 构建时限制内存使用。

使用 maven 的 camel quarkus 示例,我配置如下以使其工作:

<profiles>
    <profile>
        <id>native</id>
        <activation>
            <property>
                <name>native</name>
            </property>
        </activation>
        <properties>
            <quarkus.package.type>native</quarkus.package.type>
            <quarkus.native.additional-build-args>-J-Xmx5G</quarkus.native.additional-build-args>
        </properties>
        <build>
            <plugins>
                <plugin>
                    <groupId>org.apache.maven.plugins</groupId>
                    <artifactId>maven-failsafe-plugin</artifactId>
                    <executions>
                        <execution>
                            <goals>
                                <goal>integration-test</goal>
                                <goal>verify</goal>
                            </goals>
                        </execution>
                    </executions>
                </plugin>
            </plugins>
        </build>
    </profile>
</profiles>

使用选项 <quarkus.native.additional-build-args>-J-Xmx5G</quarkus.native.additional-build-args>

现在,您可以限制 Quarkus 的内存使用:

在您的 src/main/resources/application.properties 文件中,只需设置:

quarkus.native.native-image-xmx=2G

或者将这个选项传递给 maven:

mvn package -Dnative -Dquarkus.native.native-image-xmx=2G