目前项目的架构没有采用任何网关、采用nginx直连方式,因现在考虑加入软网关、并且采用spring cloud gateway的支持、至此升级到2.0版本、在升级期间遇到了一些问题、看了不少官方文档、将目前所遇到的问题汇总如下。
1:升级spring cloud2 先更改相应的maven相关的配置可参照:
https://blog.csdn.net/qq_36752632/article/details/79497130 注:如果你使用logback需保证logstash.logback.encoder版本在5.1以上。
2:使用工具检查对应的jar包版本有没有相应冲突如果发现出现冲突。请按照spring提供的包版本为准
3: spring cloud config中如果采用的本地存储方式,并且你在1*中根据label进行区分、请注意。
在2中请把
spring.cloud.config.label=global-config
改为
spring.cloud.config.label=/global-config
官网上介绍说明。添加的label会放入后面进行拼接地址。所以需要加入斜杠标识
4:如果使用有security安全规则并且是通过配置文件如properties配置的请更换成Bean方式进行配置。2*不在支持该方式1*上的安全配置是
security.basic.enabled=true
security.basic.path=/monitor
security.user.name=mhuang
security.user.password=huangmiao
management.security.roles=SUPERUSER
management.context-path=/monitor
management.security.enabled=true
endpoints.metrics.sensitive=false
endpoints.metrics.enabled=true
endpoints.health.sensitive=false
endpoints.health.enabled=true
在2*上官方已经屏蔽了这种方式。过时掉、官方提供的说明是需要采用自己配置Bean的方式进行配置。下方上配置代码
properties中
management.endpoints.web.exposure.include=*management.endpoints.web.base-path=/monitorspring.security.user.name=你的账号spring.security.user.password=你的密码spring.cloud.bus.trace.enabled=true
@Configuration
@EnableWebSecurity
public class WebSecurityConfig extends WebSecurityConfigurerAdapter {
@Autowired
private Environment env;
@Override
protected void configure(HttpSecurity http) throws Exception {
http.authorizeRequests().antMatchers("需要校验的url").hasRole("ADMIN")
.anyRequest().permitAll().and()
.formLogin().loginPage(env.getProperty("security.loginUrl","/login")).permitAll().and()
.logout().permitAll();
}
}
5:在特定版本中使用有DB、请更换相应的springboot包。低版本有可能会出现循环注册Bean的问题。新版springboot2.0.4修复了这个问题、如果不想升级请按照官方条件关闭SpringCloud刷新策略
5.1 方案修改作者提供的解决方式org.springframework.bootspring-boot-starter-parent2.0.4.RELEASEspring cloud 升级到org.springframework.cloudspring-cloud-dependenciesFinchley.SR1pomimport具体改动的源码可以在spring-beans 包下 AbstractBeanFactory类中的doGetBean方法
if (mbd.isSingleton()) {
sharedInstance = getSingleton(beanName, () -> { //此处在5.0.8之前出现循环Bean的时候会在创建bean对象抛出异常,有兴趣可以对比看下历史和新版的这个里面的区别
try {
return createBean(beanName, mbd, args);
}
catch (BeansException ex) {
// Explicitly remove instance from singleton cache: It might have been put there
// eagerly by the creation process, to allow for circular reference resolution.
// Also remove any beans that received a temporary reference to the bean.
destroySingleton(beanName);
throw ex;
}
});
bean = getObjectForBeanInstance(sharedInstance, name, beanName, mbd);
}
5.2 方案添加 spring.cloud.refresh.refreshable=none(使用这个配置请记住则不能通过命令进行刷新相关配置)
6:如果你当前模块使用有spring-data-redis、并且你在代码中实现了切库、请注意、2*默认已经切换成了lettuce redis客户端代理jedis成为默认的client、默认的lettuce是本地安全的链接、不允许使用垮库方式、请根据源码相应位置修改RedisTeamplate中的相关属性或者重构lettuceFactory相关工厂类定义ShareNative为false即可。就可支持垮库查询,如果量不大还可直接通过或者方式进行实现如果你采用spring-boot中的redis或者spring-data-redis 2*的话、默认现在使用lettuce client方式、需要通过下面代码进行设置、
感谢天涯的助攻地址: https://blog.csdn.net/zhongzunfa/article/details/81367355