升级前版本 | 升级后版本 | |
---|---|---|
springboot | 1.5.13.RELEASE | 2.5.2 |
springcloud | Edgware.SR3 | 2020.0.3 |
以下为升级过程中遇到的问题及解决办法
1、bootstrap配置文件不加载
升级至2.x之后发现bootstrap的配置文件不生效,经过debug之后发现在1.x版本中是根据BootstrapApplicationListener的onApplicationEvent判断是否加载bootstrap,而在2.x中是根据PropertyUtils的bootstrapEnabled来判断。主要原因就在于两者都是根据配置spring.cloud.boostrap.enbaled来判断,而该配置默认为true。但是2.x是只有该配置为false或者org.springframework.cloud.bootstrap.marker.Marker类存在才会加载bootstrap配置。
1.5.13.RELEASE版本
2.5.2版本
因此,解决该问题只需要设置spring.cloud.boostrap.enbaled = false或者在maven中引入包含Marker类的包即可。
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bootstrap</artifactId>
</dependency>
2、不允许有名称重复的bean
springboot2.5.2的配置spring.main.allow-bean-definition-overriding默认为false,该配置表示不允许有同名bean出现。
解决办法:
(1)设置spring.main.allow-bean-definition-overriding = true
(2)针对不同场景可以有不同解决办法
- 如果是本系统内多bean重复,可以通过设置别名或增加注解@Primary的方式解决
- 如果依赖第三方,则可以通过配置@ComponentScan并指定其中的excludeFilters属性
- 针对feign名称重复,可以设置唯一的contextId。
3、session不共享
产生此问题的主要原因是在session生成的服务中对CookieSerializer进行了自定义的管理,其中设置了useBase64Encoding为false,而2.5.2版本中该值默认为true,因此产生了session不共享的问题。
解决办法:自定义 CookieSerializer的bean配置
@Bean
public CookieSerializer httpSessionIdResolver() {
DefaultCookieSerializer cookieSerializer = new DefaultCookieSerializer();
cookieSerializer.setUseBase64Encoding(false);
return cookieSerializer;
}
4、Feign的GET请求无法传递RequestBody
Spring-cloud-starter-openfeign-1.4.4.RELEASE | Spring-cloud-openfeign-core-3.0.3 |
feign-core-9.5.0 | feign-core-10.12 |
feign-httpclient-9.5.0 | feign-httpclient-10.8 |
首先需要明确的是GET请求是可以传递RequestBody的,这个可以在postman中自行测试。产生该问题的主要原因是feign中默认使用HttpUrlConnection类进行网络请求处理,当发现请求中带有requestbody中时,会设置DoOutput为true,此时就会将请求自动转换为POST。但是提供服务的接口却是GET,因此就出现异常:Request method 'POST' not supported。
解决办法:
经过debug之后发现feign-core使用HttpClient是有一个加载优先级的(如上图),因此只需要保证系统不使用默认的HttpUrlConnection即可。我们此次采用的是ApacheHttpClient的方案,使用HttpUriRequest保证GET请求传递RequestBody。