一、原理
流程图
Spring Cloud Bus做配置更新步骤如下:
- 1、提交代码,利用 git 的 webhook 触发post请求给 bus/refresh
- 2、server端接收到请求并发送给Spring Cloud Bus
- 3、Spring Cloud bus接到消息并通知给其它客户端
- 4、其它客户端接收到通知,请求Server端获取最新配置
- 5、全部客户端均获取到最新的配置
二、项目改造
config-server
添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
在yml文件中配置rabbitmq的信息和开启访问接口的权限
spring:
rabbitmq:
host: 192.168.0.35
port: 5672
username: guest
password: guest
management:
endpoints:
web:
exposure:
include: "*"
config-client
添加依赖
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
在yml文件中配置rabbitmq的信息
spring:
rabbitmq:
host: 192.168.0.35
port: 5672
username: guest
password: guest
到此,server端和client端都已经配置完成,启动两个项目,可以在rabbitmq的管理界面看到多了两个队列
在server端启动后,可以在日志中找到访问的接口 /actuator/bus-refresh
在git上修改配置文件,然后访问该接口,client端将会自动重新拉取配置。
如果要配置文件变更后自动访问接口,实现自动拉取配置,需要在git的webhook上将接口配置上去即可。