关于 Java 预先编译(AOT)技术的详细说明,涵盖 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及优缺点对比
以下是关于 Java 预先编译(AOT)技术的详细说明,涵盖 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及优缺点对比:
1. 预先编译(AOT)技术详解
1.1 核心概念
- AOT(Ahead-of-Time)编译:
将 Java 代码直接编译为机器码(原生镜像),跳过 JVM 的字节码解释和 JIT 编译阶段,从而提升启动速度和运行性能。 - GraalVM:
由 Oracle 提供的多语言虚拟机,支持 AOT 编译,生成独立于 JVM 的原生可执行文件。
1.2 与传统 Java 的对比
| 特性 | 传统 Java | AOT(GraalVM) |
|---|---|---|
| 编译流程 | 编译为字节码(.class),JVM 解释执行 | 直接编译为机器码(原生镜像) |
| 启动速度 | 较慢(依赖 JVM 启动) | 极快(如 0.071 秒 vs 传统 Java 的 1 秒) |
| 资源占用 | 需 JVM 支持,内存消耗大 | 独立运行,镜像体积小(如几十 MB) |
| 平台无关性 | Write Once, Run Anywhere | 依赖操作系统(需指定平台编译) |
2. Spring Boot 3.x 集成 GraalVM
2.1 为什么选择 AOT?
- 容器化部署优化:
小体积镜像(如 Docker 镜像仅需几十 MB,传统 Java 镜像可能达几百 MB)。 - 微服务需求:
快速启动、轻量级部署,适合云原生环境。 - 性能提升:
去除 JVM 开销,减少内存占用。
2.2 环境搭建步骤
步骤1:下载并安装 GraalVM
-
Windows:
-
下载 GraalVM Community 版本(如 22.3.0,对应 JDK 17)。
-
解压后配置环境变量:
set JAVA_HOME=C:\path\to\graalvm-ce-java17-22.3.0 set PATH=%JAVA_HOME%\bin;%PATH% -
验证安装:
java -version
-
-
其他系统:
-
Linux/Ubuntu:
sudo apt-get install build-essential libz-dev zlib1g-dev -
macOS:
xcode-select --install
-
步骤2:安装 Native Image
-
Windows:
gu install native-image -
手动安装:
下载native-image-installable-*.jar并执行:gu install -L native-image-installable-*.jar
步骤3:安装编译工具
- Windows:安装 Visual Studio Community 2022(需包含 C++ 工具链)。
- Linux:确保
gcc和glibc已安装。
3. Spring Boot 项目配置
3.1 创建 Maven 项目
在 pom.xml 中添加 GraalVM 插件:
<build><plugins><!-- Spring Boot 插件 --><plugin><groupId>org.springframework.boot</groupId><artifactId>spring-boot-maven-plugin</artifactId></plugin><!-- GraalVM AOT 插件 --><plugin><groupId>org.graalvm.buildtools</groupId><artifactId>native-maven-plugin</artifactId><version>0.9.19</version></plugin></plugins>
</build>
3.2 编写测试代码
@SpringBootApplication
@RestController
public class GraalvmTestApplication {@GetMapping("/test")public String test() {return "Hello GraalVM!";}public static void main(String[] args) {SpringApplication.run(GraalvmTestApplication.class, args);}
}
4. 生成原生镜像
4.1 编译命令
在命令行中执行(需管理员权限):
mvn -Pnative native:compile
- 输出路径:
target/graalvm-test(生成的原生可执行文件)。
4.2 运行原生镜像
./target/graalvm-test # Linux/macOS
target\graalvm-test.exe # Windows
- 启动速度对比:
传统 Java 启动约 1 秒,原生镜像仅需 0.071 秒。
5. 优缺点总结
| 优点 | 缺点 |
|---|---|
| 启动速度快:减少 JVM 启动时间 | 平台依赖:需指定操作系统编译 |
| 资源占用低:镜像体积小(几十 MB) | 动态特性受限:如反射、代理需显式配置 |
| 容器化部署友好:Docker 镜像轻量 | 生态兼容性:部分库可能不支持 AOT |
| 性能优化:直接运行机器码 | 开发调试困难:原生镜像不可热部署 |
6. 使用场景建议
- 适用场景:
- 微服务、云原生应用(需快速启动和轻量部署)。
- 静态代码路径(无动态反射或代理需求)。
- 不适用场景:
- 需要频繁动态加载类或依赖反射的框架(如某些 ORM 工具)。
- 需要跨平台运行的通用 Java 应用。
7. 关键配置项
| 配置项 | 描述 | 示例 |
|---|---|---|
spring.aot.enabled | 启用 AOT 编译(Spring Boot 3.x 默认支持) | spring.aot.enabled=true |
native-image.docker-image | 生成 Docker 镜像(需安装 Docker) | native-image.docker-image=true |
native-image.build-arguments | 传递 Native Image 编译参数(如排除某些类) | -H:EnableURLProtocols=http,https |
quarkus.native.container-build | 使用容器化编译(解决本地编译工具链问题) | quarkus.native.container-build=true |
8. 总结表格
| 技术 | 启动速度 | 镜像体积 | 平台无关性 | 适用场景 |
|---|---|---|---|---|
| 传统 Java | 较慢(1s+) | 大(几百 MB) | 高 | 通用 Java 应用、动态特性需求 |
| GraalVM AOT | 极快(0.1s) | 小(几十 MB) | 低(依赖 OS) | 微服务、容器化、轻量级部署 |
9. 注意事项
- 动态代码支持:
- 需显式声明反射依赖(如
@RegisterForReflection)。 - 避免过多使用
Object.newInstance()或Class.forName()。
- 需显式声明反射依赖(如
- 依赖兼容性:
- 部分库(如 Hibernate)需特殊配置或使用替代方案。
- 开发调试:
- 建议先用传统 Java 开发,再编译为原生镜像进行部署。
通过以上步骤,开发者可快速将 Spring Boot 应用转换为高性能原生镜像,适应云原生和微服务架构的部署需求。
相关文章:
关于 Java 预先编译(AOT)技术的详细说明,涵盖 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及优缺点对比
以下是关于 Java 预先编译(AOT)技术的详细说明,涵盖 GraalVM 的配置、Spring Boot 3.x 的集成、使用示例及优缺点对比: 1. 预先编译(AOT)技术详解 1.1 核心概念 AOT(Ahead-of-Time)…...
《车辆人机工程-》实验报告
汽车驾驶操纵实验 汽车操纵装置有哪几种,各有什么特点 汽车操纵装置是驾驶员直接控制车辆行驶状态的关键部件,主要包括以下几种,其特点如下: 一、方向盘(转向操纵装置) 作用:控制车辆行驶方向…...
使用多进程和 Socket 接收解析数据并推送到 Kafka 的高性能架构
使用多进程和 Socket 接收解析数据并推送到 Kafka 的高性能架构 在现代应用程序中,实时数据处理和高并发性能是至关重要的。本文将介绍如何使用 Python 的多进程和 Socket 技术来接收和解析数据,并将处理后的数据推送到 Kafka,从而实现高效的…...
Redis 哨兵模式 搭建
1 . 哨兵模式拓扑 与 简介 本文介绍如何搭建 单主双从 多哨兵模式的搭建 哨兵有12个作用 。通过发送命令,让Redis服务器返回监控其运行状态,包括主服务器和从服务器。 当哨兵监测到master宕机,会自动将slave切换成master,然后通过…...
【网络安全 | 项目开发】Web 安全响应头扫描器(提升网站安全性)
原创项目,未经许可,不得转载。 文章目录 项目简介工作流程示例输出技术栈项目代码使用说明项目简介 安全响应头是防止常见 Web 攻击(如点击劫持、跨站脚本攻击等)的有效防线,因此合理的配置这些头部信息对任何网站的安全至关重要。 Web 安全响应头扫描器(Security Head…...
构建灵活的接口抽象层:支持多种后端数据存取的实战指南
构建灵活的接口抽象层:支持多种后端数据存取的实战指南 引言 在现代软件开发中,数据存取成为业务逻辑的核心组成部分。然而,由于后端数据存储方式的多样性(如关系型数据库、NoSQL数据库和文件存储),如何设计一套能够适配多种后端数据存取的接口抽象层,成为技术团队关注…...
计算机的发展及应用
一、计算机的发展历程 计算机的发展经历了从机械计算到电子计算的跨越,其核心驱动力是 硬件技术革新 和 体系结构演进,大致可分为以下阶段: 1. 前电子计算机时代(19世纪-20世纪40年代) 机械计算装置: 16…...
深入理解linux操作系统---第4讲 用户、组和密码管理
4.1 UNIX系统的用户和组 4.1.1 用户与UID UID定义:用户身份唯一标识符,16位或32位整数,范围0-65535。系统用户UID为0(root)、1-999(系统服务),普通用户从1000开始分配特殊UID&…...
【NLP】18. Encoder 和 Decoder
1. Encoder 和 Decoder 概述 在序列到序列(sequence-to-sequence,简称 seq2seq)的模型中,整个系统通常分为两大部分:Encoder(编码器)和 Decoder(解码器)。 Encoder&…...
Npfs!NpFsdCreate函数分析之从NpCreateClientEnd函数分析到Npfs!NpSetConnectedPipeState
第一部分: 1: kd> g Breakpoint 5 hit Npfs!NpFsdCreate: baaecba6 55 push ebp 1: kd> kc # 00 Npfs!NpFsdCreate 01 nt!IofCallDriver 02 nt!IopParseDevice 03 nt!ObpLookupObjectName 04 nt!ObOpenObjectByName 05 nt!IopCreateFile 06…...
基于PySide6与pycatia的CATIA绘图比例智能调节工具开发全解析
引言:工程图纸自动化处理的技术革新 在机械设计领域,CATIA图纸的比例调整是高频且重复性极强的操作。传统手动调整方式效率低下且易出错。本文基于PySide6+pycatia技术栈,提出一种支持智能比例匹配、实时视图控制、异常自处理的图纸批处理方案,其核心突破体现在: 操作效…...
STM32硬件IIC+DMA驱动OLED显示——释放CPU资源,提升实时性
目录 前言 一、软件IIC与硬件IIC 1、软件IIC 2、硬件IIC 二、STM32CubeMX配置KEIL配置 三、OLED驱动示例 1、0.96寸OLED 2、OLED驱动程序 3、运用示例 4、效果展示 总结 前言 0.96寸OLED屏是一个很常见的显示模块,其驱动方式在用采IIC通讯时,常用软件IIC…...
Spring Bean的创建过程与三级缓存的关系详解
以下以 Bean A 和 Bean B 互相依赖为例,结合源码和流程图,详细说明 Bean 的创建过程与三级缓存的交互。 1. Bean 的完整生命周期(简化版) #mermaid-svg-uwqaB5dgOFDQ97Yd {font-family:"trebuchet ms",verdana,arial,sa…...
IDEA 调用 Generate 生成 Getter/Setter 快捷键
快捷键不会用? 快捷键:AltInsert 全选键:CtrlA IDEA 调用 Generate 生成 Getter/Setter 快捷键 - 爱吃西瓜的番茄酱 - 博客园...
泛型的二三事
泛型(Generics)是Java语言的一个重要特性,它允许在定义类、接口和方法时使用类型参数(Type Parameters),从而实现类型安全的代码重用。泛型在Java 5中被引入,极大地增强了代码的灵活性和安全性。…...
编程思想——FP、OOP、FRP、AOP、IOC、DI、MVC、DTO、DAO
个人简介 👀个人主页: 前端杂货铺 🙋♂️学习方向: 主攻前端方向,正逐渐往全干发展 📃个人状态: 研发工程师,现效力于中国工业软件事业 🚀人生格言: 积跬步…...
实现一个动态验证码生成器:Canvas与JavaScript的完美结合
验证码(CAPTCHA)是现代网站中常见的安全机制,用于区分人类用户和自动化程序。本文将详细介绍如何使用HTML5 Canvas和JavaScript创建一个美观且功能完整的验证码生成器。 一、核心功能概述 这个验证码生成器具有以下特点: 随机生…...
python中 “with” 关键字的取舍问题
自动管理资源(自动关闭文件) 当你使用 with 打开文件时,文件会在 with 代码块结束后自动关闭,无论是否发生异常。这意味着你不需要显式地调用 f.close() 来关闭文件 示例: with open("words.txt", "r…...
【区块链安全 | 第三十九篇】合约审计之delegatecall(一)
文章目录 外部调用函数calldelegatecallcall 与 delegatecall 的区别示例部署后初始状态调用B.testCall()函数调用B.testDelegatecall()函数区别总结漏洞代码代码审计攻击代码攻击原理解析攻击流程修复建议审计思路外部调用函数 在 Solidity 中,常见的两种底层外部函数调用方…...
Nginx部署spa单页面的小bug
没部署过,都是给后端干的,自己尝试部署了一个下午终于成功了 我遇到的最大的bug是进入后只有首页正常显示 其他页面全是404,于是问问问才知道,需要这个 location / { try_files $uri $uri/ /index.html; } 让…...
linux多线(进)程编程——(6)共享内存
前言 话说进程君的儿子经过父亲点播后就开始闭关,它想要开发出一种全新的传音神通。他想,如果两个人的大脑生长到了一起,那不是就可以直接知道对方在想什么了吗,这样不是可以避免通过语言传递照成的浪费吗? 下面就是它…...
【愚公系列】《Python网络爬虫从入门到精通》050-搭建 Scrapy 爬虫框架
🌟【技术大咖愚公搬代码:全栈专家的成长之路,你关注的宝藏博主在这里!】🌟 📣开发者圈持续输出高质量干货的"愚公精神"践行者——全网百万开发者都在追更的顶级技术博主! 👉 江湖人称"愚公搬代码",用七年如一日的精神深耕技术领域,以"…...
信息安全管理与评估2021年国赛正式卷答案截图以及十套国赛卷
2021年全国职业院校技能大赛高职组 “信息安全管理与评估”赛项 任务书1 赛项时间 共计X小时。 赛项信息 赛项内容 竞赛阶段 任务阶段 竞赛任务 竞赛时间 分值 第一阶段 平台搭建与安全设备配置防护 任务1 网络平台搭建 任务2 网络安全设备配置与防护 第二…...
讲解贪心算法
贪心算法是一种常用的算法思想,其在解决问题时每一步都做出在当前状态下看起来最优的选择,从而希望最终能够获得全局最优解。C作为一种流行的编程语言,可以很好地应用于贪心算法的实现。下面我们来讲一篇关于C贪心算法的文章。 目录 贪心算法…...
高并发秒杀系统设计:关键技术解析与典型陷阱规避
电商、在线票务等众多互联网业务场景中,高并发秒杀活动屡见不鲜。这类活动往往在短时间内会涌入海量的用户请求,对系统架构的性能、稳定性和可用性提出了极高的挑战。曾经,高并发秒杀架构设计让许多开发者望而生畏,然而࿰…...
微信小程序实战案例 - 餐馆点餐系统 阶段 2 – 购物车
阶段 2 – 购物车(超详细版) 目标 把“加入购物车”做成 全局状态,任何页面都能读写在本地 持久化(关闭小程序后购物车仍在)新建 购物车页:数量增减、总价实时计算、去结算入口打 Git Tag v2.0‑cart 1. …...
Qt 元对象系统探秘:从 Q_OBJECT 到反射编程的魔法之旅
背景说明:Qt 背后的「魔法引擎」 如果你曾用 Qt 写过信号槽,或是在设计器里拖过控件改属性,一定对这个框架的“动态性”印象深刻: 无需手动调用,信号能自动连接到槽函数;无需编译重启,界面上修…...
sql 向Java的映射
优化建议,可以在SQL中控制它的类型 在 MyBatis 中,如果返回值类型设置为 java.util.Map,默认情况下可以返回 多行多列的数据...
Visual Studio未能加载相应的Package包弹窗报错
环境介绍: visulal studio 2019 问题描述: 起因:安装vs扩展插件后,重新打开Visual Studio,报了一些列如下的弹窗错误,即使选择不继续显示该错误,再次打开后任然报错; 解决思路&am…...
【HD-RK3576-PI】Docker搭建与使用
硬件:HD-RK3576-PI 软件:Linux6.1Ubuntu22.04 1.Docker 简介 Docker 是一个开源的应用容器引擎,基于 Go 语言开发,遵循 Apache 2.0 协议。它可以让开发者将应用程序及其依赖项打包到一个轻量级、可移植的容器中,并在任…...
