最近开发新项目顺便升级 Springcloud Dalston.SR5 到当前最新版 Finchley.SR1
由于 springboot1.5.10到当前最新版 spring2.0.1版本 升级修改比较大,记录一下
首先修改一下springboot cloud 版本号其他不用变
部分配置文件名称修改了 添加一下以下依赖会提示如何迁移
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-properties-migrator</artifactId>
</dependency>
</dependencies>
artifactId
首先遇到的问题 cloud的部分jar的artifactId发生了变化
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-eureka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-feign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-sleuth-stream</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-zuul</artifactId>
</dependency>
修改为
#区分client和server了 设置对应的
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-openfeign</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-stream</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
feign
feign的包名发生改变
org.springframework.cloud.netflix.feign
变更为
org.springframework.cloud.openfeign
Zuul
ZuulFallbackProvider 接口 已经过时了 使用FallbackProvider 即可方法基本一致
此外添加了String route, Throwable cause 参数可以根据不同的异常做不同降级处理
ZipKin
zipkin在最新版本中不推荐自建
可手动下载jar 直接运行 link
启动命令,相关配置 通过启动参数添加
RABBIT_URI=amqp://guest:guest@localhost:5672 STORAGE_TYPE=mysql MYSQL_DB=ag_zipkin MYSQL_USER=root MYSQL_PASS=123456 MYSQL_HOST=localhost MYSQL_USE_SSL=false java -jar zipkin.jar
也可继续使用老版本的不升级springboot
HikariCP
由于springboot2 默认使用了 HikariCP 所以原有的替换HikariCP pom里面可以去掉了 如果需要其他的需要替换HikariCP 跟之前一样移除对应依赖
endpoints
所有 endpoints 默认情况下都已移至 /actuator 无论您的应用程序中是否存在和配置 Spring Security,只有端点/health和/info端点都是暴露的 另外端点的格式和具体端点都有很多变化
springboot-admin
由于endponits 变化比较大,需要升级 springboot-admin 为 2.0.1
修改pom依赖
<dependency>
<groupId>de.codecentric</groupId>
<artifactId>spring-boot-admin-starter-server</artifactId>
<version>2.0.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-security</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
</dependency>
<dependency>
<groupId>org.jolokia</groupId>
<artifactId>jolokia-core</artifactId>
</dependency>
由于 Spring Boot 2.0 的 Actuator 只暴露了 /health、/info 两个端口(为了安全考虑), 所以要配置 management.endpoints.web.exposure.include 的属性
management:
endpoints:
web:
exposure:
include: "*"
配置文件修改
server
server.context-path
修改为
server.servlet.context-path
endpoints
#全局的endpoints设置已失效
endpoints:
enabled: true
sensitive: false
Flyway
Flyway 配置键被移动到spring命名空间(即spring.flyway)
redis
由于 jedis 升级为lettuce spring.redis.pool 修改为spring.reids.lettuce.pool 也可以移除 lettuce的依赖加上 jredis的
bug
如果出现以下循环引用异常 请升级springboot到2.0.4以上版本 或者设置spring.cloud.refresh.refreshable=none (但是同时也关闭了配置的刷新)
The dependencies of some of the beans in the application context form a cycle:
servletEndpointRegistrar defined in class path resource [org/springframework/boot/actuate/autoconfigure/endpoint/web/ServletEndpointManagementContextConfiguration.class]
↓
healthEndpoint defined in class path resource [org/springframework/boot/actuate/autoconfigure/health/HealthEndpointConfiguration.class]
↓
org.springframework.boot.actuate.autoconfigure.jdbc.DataSourceHealthIndicatorAutoConfiguration
┌─────┐
| dataSource
↑ ↓
| scopedTarget.dataSource defined in class path resource [org/springframework/boot/autoconfigure/jdbc/DataSourceConfiguration$Hikari.class]
↑ ↓
| org.springframework.boot.autoconfigure.jdbc.DataSourceInitializerInvoker
└─────┘