上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

最近由于各方面的原因在准备升级 Spring Cloud 和 Spring Boot , 经过一系列前置的调研和分析,决定把Spring Boot 相关版本从 2.1.6 升级到 2.7.5,Spring Cloud 相关版本从 Greenwich.SR1 升级为 2021.0.4 。
升级包含基础的业务服务代码的升级改造适配,还有就是中间件一堆代码的改造 , 上周经历了一周的修改,用来测试的服务仍然还没有跑起来,所以这篇文章我会记录下来这升级过程中的一些问题,由于革命仍未成功,所以这是上篇 。
1. hibernate-validator包下的类报错在 Spring Boot 2.3版本之后,spring-boot-starter-web 中没有依赖 hibernate-validator 。
解决方案:使用新的依赖 。
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-validation</artifactId></dependency>2. ApplicationEnvironmentPreparedEvent类改变Spring Boot 2.4版本之后,ApplicationEnvironmentPreparedEvent 构造函数新增了ConfigurableBootstrapContext,业务代码还好,应该都用不上这个类,中间件代码使用到的地方都需要修改 。
解决方案:修改代码 。
public ApplicationEnvironmentPreparedEvent(ConfigurableBootstrapContext bootstrapContext,SpringApplication application, String[] args, ConfigurableEnvironment environment) {super(application, args);this.bootstrapContext = bootstrapContext;this.environment = environment; }

上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

文章插图
3. junit依赖升级升级后的junit版本默认是junit5(我没有去确认是哪个版本发生了变化),升级之后包名发生了改变,所有的测试用例都需要修改 。
import org.junit.jupiter.api.Assertions;import org.junit.jupiter.api.Test;另外发现Assert类不存在了,可以改用Assertions
Assertions.assertNotNull(result);解决方案:修改代码!
4. Spring Cloud兼容问题由于测试过程中先升级的 Spring Boot,发现 Spring Cloud 使用到的低版本代码不兼容,升级到文章开头说的版本之后问题解决 。
比如下面的 spring-cloud-context 启动时候报错 。
上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

文章插图
5. SpringApplicationRunListener类改变和第二个问题比较类似,SpringApplicationRunListener 中这两个方法新增了 ConfigurableBootstrapContext,对应实现类都需要修改,这个应该无论在业务还是中间件代码中都应该有大量的使用 。
解决方案:修改代码!
default void starting(ConfigurableBootstrapContext bootstrapContext) {}default void environmentPrepared(ConfigurableBootstrapContext bootstrapContext,ConfigurableEnvironment environment) {}6. ServerProperties变更spring-boot-autoconfigure 包下 ServerProperties 中的内部类 Tomcat 属性变更,获取最大线程数方法发生改变 。
原写法:serverProperties.getTomcat().getMaxThreads()
解决方案:serverProperties.getTomcat().getThreads().getMax()
7. spring-cloud-openfeign中移除ribbon和hystrix依赖Commit地址:https://github.com/spring-cloud/spring-cloud-openfeign/commit/8a08e1ec4b4f0d40193a4ea9c03afdeffe3110a6
这个提交把 spring-cloud-openfeign 里面关于 ribbon 和 hystrix 的依赖相关代码全部删除了,这个 commit 我找了一遍 issue 和 PR,都没有发现相关说明,大佬直接删的 , 具体原因不清楚为什么直接全删干净了 。
比如我的启动报错:
Caused by: java.lang.ClassNotFoundException: org.springframework.cloud.openfeign.ribbon.LoadBalancerFeignClient解决方案:手动引入新的依赖 。
<dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-starter-netflix-ribbon</artifactId><version>2.2.10.RELEASE</version> </dependency>8. bootstrap.properties/yml 配置文件不生效根据 Spring Cloud 配置方式 , 发现很多业务的本地配置配置在 bootstrap.properties中 , 新版本默认会不生效 。
老版本中 spring.cloud.bootstrap.enabled 默认为 true 。
上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

文章插图
新版本改过之后默认是false了,导致一堆配置不生效 。
上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

文章插图

上 我服了!SpringBoot升级后这服务我一个星期都没跑起来!

文章插图
解决方案:手动设置spring.cloud.bootstrap.enabled=true
9. spring-cloud-netflix-eureka-client中移除ribbon和hystrix依赖和第七个问题差不多,

推荐阅读