最近由于各方面的原因在准备升级 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; }
文章插图
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
启动时候报错 。文章插图
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 。文章插图
新版本改过之后默认是false了,导致一堆配置不生效 。
文章插图
文章插图
解决方案:手动设置
spring.cloud.bootstrap.enabled=true
9. spring-cloud-netflix-eureka-client中移除ribbon和hystrix依赖和第七个问题差不多,
推荐阅读
- 解压包被上了密码,怎么破解(rar解压密码怎么解)
- Redisson源码解读-公平锁
- 叫我大掌柜2022巅峰商会战活动详解攻略
- BODYCOMBAT认证之路
- 国家幼儿园建设标准 最新幼儿园建设标准
- 网上打字赚钱是真的吗(在线文字录入赚钱)
- 有一个打字赚钱的app叫什么(手机上练习打字的app)
- 为什么还有人相信网络上的“打字赚钱”骗局
- 网上打字赚钱的有哪些(网上打字挣钱日结)
- 一 我要涨知识 —— TypeScript 常见面试题