动力节点王鹤SpringBoot3笔记-了解AOT和GraalVM

news/2024/11/30 2:41:04/

9 了解AOT和GraalVM

9.1 提供性能的技术

什么是AOT
Ahead-of-Time Compilation :预编译(提前编译)它在 JEP-295 中描述,并在 Java 9 中作为实验性功能添加。
AOT是提升Java程序性能的一种方法,特别是提供JVM的启动时间。在启动虚拟机之前,将Java类编译为本机代码。改进小型和大型Java应用程序的启动时间。

JIT (just in time)
JIT是现在JVM提高执行速度的技术,JVM执行Java字节码,并将经常执行的代码编译为本机代码。这称为实时 (JIT) 编译。
当JVM发现某个方法或代码块运行特别频繁的时候,就会认为这是“热点代码”(Hot Spot Code)。然后JIT会把“热点代码”编译成本地机器相关的机器码,并进行优化,然后再把编译后的机器码缓存起来,以备下次使用。
JVM 根据执行期间收集的分析信息决定 JIT 编译哪些代码。JIT编译器速度很快,但是Java程序非常大,以至于JIT需要很长时间才能完全预热。不经常使用的Java方法可能根本不会被编译。

特点:在程序执行时,边运行代码边编译。JIT编译需要时间开销,空间开销,只有对执行频繁的代码才值得编译。

AOT:静态的
JIT:动态的

9.2 Native Image

native image: 原生镜像(本机镜像)

native image is a technology to ahead-of-time compile Java code to a standalone executable, called a native image
本机映像是一种预先将Java代码编译为独立可执行文件的技术,称为本机映像(原生镜像)。镜像是用于执行的文件。
通过镜像构建技术(工具)生成镜像文件(native image)。
native image既是技术的名词也指他的生成的可执行文件。
native image支持基于jvm的语言,例如Java, Scala, Clojure, Kotlin

原生镜像文件内容包括应用程序类、来自其依赖项的类、运行时库类和来自JDK的静态链接本机代码(二进制文件可以直接运行,不需要额外安装JDK),本机映像运行在GraalVM上,具有更快的启动时间和更低的运行时内存开销。

在AOT模式下,编译器在构建项目期间执行所有编译工作,这里的主要想法是将所有的 “繁重工作”–昂贵的计算–转移到构建时间。也就是把项目都要执行的所有东西都准备好,具体执行的类,文件等。最后执行这个准备好的文件,此时应用能够快速启动。减少内存,cpu开销(无需运行时的JIT的编译)。因为所有东西都是预先计算和预先编译好的。

9.3 Native Image builder

Native Image builder(镜像构建器):是一个实用程序,用于处理应用程序的所有类及其依赖项,包括来自JDK的类。它静态地分析这些数据,以确定在应用程序执行期间可以访问哪些类和方法。然后,它预先将可到达的代码和数据编译为特定操作系统和体系结构的本机可执行文件

9.4 GraalVM

GraalVM 是一个高性能 JDK 发行版,旨在加速用 Java 和其他 JVM 语言编写的应用程序,同时支持 JavaScript、Ruby、Python 和许多其他流行语言。GraalVM 的多语言功能可以在单个应用程序中混合多种编程语言,同时消除外语调用成本。GraalVM是支持多语言的虚拟机。

GraalVM 是 OpenJDK 的替代方案,包含一个名为 native image 的工具,支持预先(ahead-of-time,AOT)编译。GraalVM 执行native image文件启动速度更快,使用的 CPU 和内存更少,并且磁盘大小更小。这使得Java在云中更具竞争力

目前,AOT的重点是允许使用GraalVM将Spring应用程序部署为本机映像。Spring Boot 3中使用GraalVM方案提供Native Image支持。

GraalVM的 "native image "工具将Java字节码作为输入,输出一个本地可执行文件。为了做到这一点,该工具对字节码进行静态分析。在分析过程中,该工具寻找你的应用程序实际使用的所有代码,并消除一切不必要的东西。native image是封闭式的静态分析和编译,不支持class的动态加载,程序运行所需要的多有依赖项均在静态分析阶段完成

9.5 AOT的操作步骤:

使用SpringBoot或者Spring创建项目, GraalVM的native image build生成 原生镜像文件,在GraalVM上执行镜像文件。


http://www.ppmy.cn/news/41645.html

相关文章

LAZADA将缩短履约时效,卖家发货倍感压力

Lazada的跨境卖家们,恐怕又要头疼了。 近日, Lazada官方宣布,为了提升消费者体验,平台将调整商家履约订单时效。从2023年5月4日起生成的订单履约时效将有所更新。 具体而言,内地、香港和Laz Go Global的履约节点为“点…

elasticsearch 认知

1.大数据领域需要解决以下三个问题 如何存储数据 传统的关系数据库(MySQL、Oracle、和Access等)主导了20世纪的数据存储模式,但当数据量达到太字节级,甚至拍字节级时,关系型数据库表现出了难以解决的瓶颈问题。为了解决…

SDUT操作系统课程(CATS)专题一+专题三(参考总结)

CATS专题一+进程同步模型.信号量机制 总结:先看进程优先级,优先级高的进程先进行,一般在CATS中第三个才会出现P/V操作 两个信号量都初始值为零,P操作为信号量减一 如:X=X-1=-1. V操作为信号量加一 如:Y=Y+1=1. 其中如果信号量为-1时,当前进程为阻塞状态,切换到另一…

你真的会自动化测试?自动化测试技术选型抉择

自动化测试框架 在学习自动化测试或者实践自动化测试时,我们一定会对一个名词不陌生,那就是“自动化测试框架”,而有些人也将Selenium、Appium这样的工具也称之为“自动化测试框架”,那么到底自动化测试框架如何理解呢&#xff1…

7nm舱泊一体SoC的新玩家

2016年,高通推出基于14纳米工艺的汽车座舱芯片骁龙820A,彼时,传统座舱SoC霸主NXP主推的是28纳米工艺的iMX8系列。不过,两款芯片都没有能够达到预期的量产效果。 真正的时代变革,来自于高通在2019年发布的全球首款量产7…

Zookeeper集群 + Fafka集群

目录 第一章Zookeeper 概述 1.1.Zookeeper 定义 1.2.Zookeeper 工作机制 1.3.Zookeeper 特点 1.4.Zookeeper 数据结构 1.5.Zookeeper 应用场景 1.6.Zookeeper 原理之选举机制 1.7.部署 Zookeeper 集群 总结 第二章消息队列概述 2.1消息队列需求原因 2.2消息队列的优…

SQL Server的死锁说明

死锁指南一、了解死锁二、检测并结束死锁2.1、可能死锁的资源三、处理死锁四、最大限度地减少死锁4.1、以相同的顺序访问对象4.2、避免事务中的用户交互4.3、保持交易简短且在一个批次中4.4、使用较低的隔离级别4.5、使用基于行版本控制的隔离级别4.6、使用绑定连接4.7、停止事…

MySql经典语句练习50题 ---- 1 ~ 9题

目录 1、查询"01"课程比"02"课程成绩高的学生的信息及课程分数: 2、查询"01"课程比"02"课程成绩低的学生的信息及课程分数: 3、查询平均成绩大于等于60分的同学的学生编号和学生姓名和平均成绩: 4、…