SpringBoot优化启动速度实现过程
作者:tomorrow.hello
本文主要介绍了SpringBoot启动慢的原因,并提供了多种针对性优化方案,如延迟Bean初始化、关闭JMX、减少组件扫描、升级JDK及SpringBoot版本等,旨在提升应用启动速度
1.优化后优势
启动速度更快,提升水平扩展的启动速度。占用资源更少,打包体积更小。
2. SpringBoot启动慢的原因
- 过多的自动配置:Spring Boot 的自动配置功能虽然强大,但当项目依赖增多,它会尝试为各类依赖自动配置,这无疑会延长启动时间。
- 大量的 Bean 初始化:每个 Spring Bean 的初始化都要耗费一定时间,尤其是那些依赖众多的复杂 Bean,比如某些 Service 或 Controller。项目中 Bean 数量越多,启动速度就越受影响。
- 不必要的组件扫描:Spring Boot 依据配置文件或注解扫描指定包中的所有类。若包内存在大量与应用无关的类,启动速度必然大打折扣。
- 数据源初始化缓慢:在大型项目里,数据库连接池的初始化以及数据源配置可能耗时较长,特别是在数据库连接速度欠佳,或者需要执行大量初始化 SQL 脚本时。
- 应用依赖繁杂:引入过多依赖库,会致使应用启动时加载海量类和资源,进而拖慢启动速度。
3. 延迟 Bean 初始化
Springboot中一般拥有了很多的耗时任务,比如创建数据库连接,初始化线程池等。我们可以通过延迟加载(懒加载),来优化启动启动速度。
从 Spring Boot 2.2 版本起,可通过在application.properties中配置spring.main.lazy-initialization=true来开启延迟初始化。
配置文件方式:
spring.main.lazy-initialization=true
代码方式:
public static void main(String[] args) {
SpringApplication springApplication = new SpringApplication();
// 开启延迟初始化
springApplication.setLazyInitialization(true);
// 启动SpringApplication
ConfigurableApplicationContext context = springApplication.run(LXbootWebProgram.class, args);
}3.1 创建扫描索引@Indexed
引入依赖,并在启动类上增加@Indexed
Spring5之后提供了spriing-context-indexer功能,可以通过在编译时创建一个静态候选列表来提高大型应用程序的启动性能。
spring-context-indexer依赖,编译时,Spring 会在META-INF\spring.components中生成额外文件,启动时会自动使用该文件,无需额外配置。
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-indexer</artifactId>
<optional>true</optional>
</dependency>
3.2 关闭JMX
JMX的全称为Java Management Extensions. 顾名思义,是管理Java的一种扩展。
这种机制可以方便的管理正在运行中的Java程序。
常用于管理线程,内存,日志Level,服务重启,系统环境等。
spring.jmx.enabled=true
3.3 其他方式
- 减少@ComponentScan @SpringbootApplication扫描
- 设置JVM参数 -noverify,不对类进行验证
- AOPO面向切面尽量不使用注解方式,这样能减少启动扫描的耗时
- 关闭一些不需要的endpoint监控接口
- 排除多余jar
- swagger扫描接口时,指定扫描路径到类下
- Fegin客户端接口扫描范围缩小
3.4 升级jdk17
JDK升级后GC垃圾回收器也进行了一定的优化。
- JDK12之后使用G1
- JDK13之后使用ZGC
3.5 升级Springboot3
springboot3使用GraalVM将springboot的应用程序编译成本地可执行的镜像文件,可以很多的提前启动速度和内存优化。
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
