一、前置条件
JDK 版本要求
宝子们,升级 Spring Boot 3.X 的话,必须得用 JDK 17 以上的版本哦!像我,就果断选择了 JDK 21,毕竟它对 Spring AI 的支持超给力,能让咱在技术探索的道路上一路狂飙~
验证方式超简单,在命令行里输入:
java -version |
轻松查看版本,是不是超酷!
构建工具兼容性
构建工具方面,Maven 得>= 3.6.3 。我用的是 apache - maven - 3.8.8,运行起来超顺滑,就像丝滑的巧克力,完全没卡顿,稳稳拿捏升级的前置条件。
SpringBoot3.X默认内嵌tomcat版本
服务器中间件方面Tomcat >=10.1.x(支持Servlet 5.0+),可自己手工指定版本
二、核心变更适配
Jakarta EE 9+ 迁移
代码变化来咯,看这里:
- import javax.servlet.http.HttpServletRequest; + import jakarta.servlet.http.HttpServletRequest; |
这一变动影响范围还挺广,Servlet API、JPA(从 javax.persistence 变为 jakarta.persistence )、Bean Validation(从 javax.validation 变为 jakarta.validation )都在其中。别慌,解决办法超简单,借助 IDE 的全量替换功能,一键把 javax. 替换成 jakarta.,轻松搞定,简直 yyds!
Spring Security 6.x 配置重构
代码风格大变身啦:
// 2.x旧写法(已经out啦) @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.authorizeRequests().anyRequest().authenticated(); } } // 3.x新写法,更简洁更时尚 @Configuration @EnableWebSecurity public class SecurityConfig { @Bean public SecurityFilterChain securityFilterChain(HttpSecurity http) throws Exception { return http .authorizeHttpRequests(auth -> auth .anyRequest().authenticated() ) .build(); } } |
赶紧跟上这波时尚潮流,让代码也变得 “潮酷” 起来。
三、关键组件兼容性
组件 | 最低要求版本 | 注意事项 |
MySQL | 8.0 | 方言类名变更(MySQL5Dialect → MySQLDialect) |
Thymeleaf | 3.1.x | 严格模式模板校验 |
Spring Data JPA | 3.0.x | 分页查询返回类型变更(Page → Slice) |
Spring Kafka | 3.0.x | 消费者位点管理策略调整 |
Spring Cloud | 2022.0.x+ | Bootstrap 上下文默认禁用 |
每个组件都有自己的 “小脾气”,升级时可一定要按照要求来,不然它就可能给你 “闹别扭” 哦。
四、分阶段升级策略
过渡阶段
当然要是求稳的话可以不要一下子把升级的版本跨度弄得太大,咱先升级到 Spring Boot 2.7.x(这可是 2.x 的最后一个版本哦),JDK版本先用11或者17,然后把所有弃用警告都清理干净,就像打扫房间一样,干干净净再继续新升级新的版本。
五、验证与监控
启动时版本验证
在代码里加上这个,启动时就能看到 Spring Boot 的版本啦:
@SpringBootApplication public class Application { public static void main(String[] args) { System.out.println("Spring Boot Version: " + SpringBootVersion.getVersion()); SpringApplication.run(Application.class, args); } } |
时刻掌握版本信息,升级更安心。
六、常见问题速查
错误现象 | 解决方案 |
java.lang.NoClassDefFoundError: jakarta/servlet/http/HttpServletRequest | 检查是否遗漏 javax→jakarta 包名替换 |
Parameter 0 of constructor in ... required a bean of type ... | 添加显式包扫描:@SpringBootApplication (scanBasePackages = {"com.***.***"}) |
Spring Security 6: AuthenticationManager cannot be cast to ... | 使用新式配置注入 AuthenticationManager |
项目中存在循环依赖(这是本次升级改造最难解决的问题) | 看下方循环依赖问题解决方案 |
遇到问题别着急,按照这些解决方案,分分钟就能解决,让升级之路畅通无阻。
七、循环依赖问题解决方案
第一种 开启循环依赖(其实并没有根本解决问题,适合旧项目的升级改造,减少工作量)
Spring默认已经不在支持循环依赖,在配置文件中重新开启循环依赖支持
spring: main:
|
第二种 启动类mian方法改造(这个方法有个bug,如果项目用war包的方式打包,启动的时候还是会循环依赖的错误,用jar包的方式则不会)
new SpringApplicationBuilder(MssSvnApplication.class).allowCircularReferences(true).run(args);
第三种 使用懒加载标签
@Lazy // 使用懒加载 |
第四种 每次使用的时候就去Bean工厂里去获取,这样就不存在循环依赖了(网上介绍的方案感觉不是很靠谱)新项目有时间还是改代码从根本上解决问题