首页 >Java >java教程 >使用 Quarkus 和 GraalVM 本机映像增强 Java 微服务

使用 Quarkus 和 GraalVM 本机映像增强 Java 微服务

王林
王林原创
2024-08-30 06:03:02365浏览

在现代软件开发的动态格局中,微服务已成为最受欢迎的架构方法。虽然这种方法提供了许多优点,但它也并非没有挑战。传统的基于 JVM 的服务经常会出现内存占用过大、启动时间过长和 CPU 使用率过高等问题。这些挑战不仅会影响技术方面,还会产生财务影响,从而显着影响运行和维护软件解决方案的总体成本。

什么是 GraalVM 本机映像?

GraalVM Native Image 是 GraalVM 的一个关键特性,它是一个高性能运行时,提供对各种编程语言和执行模式的支持。具体来说,GraalVM Native Image 允许您提前将 Java 应用程序编译为独立的本机可执行文件,从而在运行时无需使用 Java 虚拟机 (JVM)。与传统的 JVM 相比,这种创新方法生成的可执行文件表现出几乎瞬时的启动时间并显着减少了内存消耗。这些本机可执行文件经过精心制作,仅包含应用程序功能所必需的基本类、方法和依赖库。除了技术实力之外,GraalVM Native Image 还成为具有深远影响的战略解决方案。它不仅克服了技术挑战,还引入了令人信服的财务案例。通过促进高效、安全且可即时扩展的云原生 Java 应用程序的开发,GraalVM 在优化资源利用率和提高成本效益方面发挥了重要作用。从本质上讲,它在提高当代动态环境中软件解决方案的性能和财务效率方面发挥着关键作用。

技术挑战和财务影响

1。大内存占用

技术影响
由于类加载和加载类的元数据,传统的基于 JVM 的服务通常会产生大量内存开销。


财务案例
高内存消耗意味着基础设施成本增加。 GraalVM 消除了加载类的元数据和其他优化,可以更有效地利用资源,从而节省潜在的成本。

2。延长开始时间

技术影响
微服务中的冷启动可能会导致响应时间更长,影响用户体验并可能导致服务降级。


财务案例
延长启动时间不仅会影响用户满意度,还会导致更高的运营成本。 GraalVM 的优化,例如消除类加载开销和在构建过程中预生成映像堆,大大减少了启动时间,有可能最大限度地减少运营费用。

3。 CPU 使用率高

技术影响
传统 JVM 通常会在启动期间消耗 CPU 周期来进行分析和即时 (JIT) 编译。


财务案例
CPU 使用率过高会导致云基础设施成本增加。 GraalVM 避免了分析和 JIT 开销,直接有助于减少 CPU 消耗,从而转化为云使用中潜在的成本节省。

解决冷启动问题

微服务,尤其是在无服务器或容器化环境中,经常面临冷启动问题,影响响应时间和用户体验。 GraalVM 通过实施多项优化来应对这一挑战:

1。没有类加载开销

传统的Java应用程序依赖运行时的类加载来动态加载和链接类。此过程会带来开销,特别是在启动阶段。 GraalVM 通过称为静态或提前 (AOT) 编译的过程最大限度地减少了这种开销。这涉及预加载、链接和部分启动应用程序所需的所有类。因此,在应用程序启动期间不需要运行时类加载。

2。消除解释代码

传统的 Java 虚拟机在应用即时 (JIT) 编译之前依赖于解释执行模式。这可能会导致启动延迟和 CPU 使用率增加。本机可执行文件不包含解释代码,进一步有助于加快启动时间。

3。没有分析和 JIT 开销

GraalVM 无​​需启动即时 (JIT) 编译器,减少启动期间的 CPU 使用率。

4。构建时生成图像堆

GraalVM 的本机映像实用程序允许在构建过程中执行特定类的初始化过程。这会生成包含预初始化部分的映像堆,从而加快应用程序的启动速度。

Oracle GraalVM 的本机映像实用程序已证明启动时间比传统的基于 JVM 的应用程序快了近 100 倍。下图说明了运行时内存需求的大幅减少,展示了 GraalVM 与 HotSpot 相比的效率(图 1)。

Turbocharge Java Microservices with Quarkus and GraalVM Native Image

图 1 – 本机可执行文件几乎立即启动 (oracle.com)


实现更精简的内存占用

GraalVM 通过以下优化有助于降低内存占用:

1。加载的类没有元数据

GraalVM 避免在非堆内存中存储动态加载类的元数据。在构建过程中,会预先加载和链接必要的类信息,从而最大限度地减少运行时对额外元数据的需求。

2。没有分析数据或 JIT 优化

由于字节码已经在本机代码中,GraalVM 无​​需收集分析数据以进行 JIT 优化,从而减少了内存开销。

3。隔离技术

GraalVM 引入了 Isolates,一种将堆划分为更小、独立“堆”的技术,从而提高效率,特别是在请求处理场景中。

通常,与在 JVM 上运行相比,它消耗的内存最多减少 5 倍(图 2

Turbocharge Java Microservices with Quarkus and GraalVM Native Image

图 2 – 与 Go 或 Java HotSpot(oracle.com) 相比的本机可执行文件内存


总之,GraalVM 的本机映像实用程序为微服务带来的挑战提供了变革性的解决方案,解决了启动时间、内存占用和 CPU 使用问题。通过采用 GraalVM,开发者可以创建云原生 Java 应用程序,这些应用程序不仅高效、安全,而且还提供卓越的用户体验。

带有 Quarkus 的原生 Java

要将 Quarkus 服务编译为本机映像,可以使用多种方法。虽然本文不会深入研究 Quarkus 原生构建过程,但它确实提供了基本步骤的概述。

在继续使用任何方法构建本机映像之前,在 pom.xml 文件中设置正确的本机配置文件至关重要。添加以下配置文件:

<profiles>
  <profile>
    <id>native</id>
    <properties>
      <quarkus.package.type>native</quarkus.package.type>
    </properties>
  </profile>
</profiles>

使用已安装的 GraalVM 生成本机可执行文件

使用以下命令检查您的 GraalVM 版本:

./gu info native-image

此命令将显示已安装的 GraalVM 版本:

Downloading: Component catalog from www.graalvm.org
Filename : https://github.com/graalvm/graalvm-ce-builds/releases/download/vm-22.3.0/native-image-installable-svm-java19-linux-amd64-22.3.0.jar
Name     : Native Image
ID       : native-image
Version  : 22.3.0
GraalVM  : 22.3.0
Stability: Experimental
Component bundle native-image cannot be installed
        - The same component Native Image (org.graalvm.native-image[22.3.0.0/55b341ca1bca5219aafa8ed7c8a2273b81d184dd600d8261c837fc32d2dedae5]) is already installed in version 22.3.0

要创建本机可执行文件,请使用:

./mvnw install -Dnative

这些命令在目标目录中生成一个 *-runner 二进制文件,允许您运行本机可执行文件:

./target/*-runner

在未安装 GraalVM 的情况下创建本机可执行文件

如果在本地安装 GraalVM 存在挑战,可以使用容器内构建:

./mvnw install -Dnative -Dquarkus.native.container-build=true -Dquarkus.native.builder-image=graalvm

此命令启动 Docker 容器内的构建并提供必要的映像文件。然后您可以通过以下方式启动应用程序:

./target/*-runner

如果构建本机镜像具有挑战性,RedHat 团队提供了专门为 Quarkus 框架设计的 GraalVM 发行版,称为 Mandrel。心轴流线型
GraalVM,仅专注于 Quarkus 应用程序必需的本机映像功能。要使用心轴,请按照下列步骤操作:

  1. 确定适当的 Mandrel 版本 Mandrel 存储库

  2. 在 application.properties 文件中设置 Mandrel 版本:

quarkus.native.builder-image=quay.io/quarkus/ubi-quarkus-mandrel-builder-image:23.0.1.2-Final-java17

3.运行Maven构建命令:

./mvnw clean install -Pnative

手动创建容器

对于那些喜欢手动控制容器创建的人,可以采用多阶段 Docker 构建。

FROM quay.io/quarkus/ubi-quarkus-mandrel-builder-image:23.0.1.2-Final-java17 AS build
COPY --chown=quarkus:quarkus mvnw /app/mvnw
COPY --chown=quarkus:quarkus .mvn /app/.mvn
COPY --chown=quarkus:quarkus pom.xml /app/
USER quarkus
WORKDIR /app
RUN ./mvnw -B org.apache.maven.plugins:maven-dependency-plugin:3.6.1:go-offline
COPY src /app/src
RUN ./mvnw package -Dnative

FROM quay.io/quarkus/quarkus-micro-image:2.0
WORKDIR /app/
COPY --from=build /app/target/*-runner /app/application

RUN chmod 775 /app /app/application \
  && chown -R 1001 /app \
  && chmod -R "g+rwX" /app \
  && chown -R 1001:root /app

EXPOSE 8080
USER 1001

CMD ["./application", "-Dquarkus.http.host=0.0.0.0"]

此 Dockerfile 编排多阶段构建,从而生成包含 Quarkus 应用程序的 Docker 映像。执行此 Dockerfile 以生成 Docker 映像,准备好运行您的 Quarkus 应用程序。

概括

GraalVM Native Image 是一项强大的技术,可以彻底改变您开发和部署 Java 微服务的方式。通过采用 GraalVM Native Image,您可以创建以下微服务:

  • 更快
  • 更具可扩展性
  • 部署更简单
  • 性价比更高

GraalVM Native Image 是云原生 Java 开发的关键推动者,可以帮助您实现业务所需的性能、可扩展性和成本节约。

以上是使用 Quarkus 和 GraalVM 本机映像增强 Java 微服务的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn