在配置中心中,程序在启动的时候才会读取配置文件的内容,如果在程序启动后,修改配置文件中的内容,程序是不能感知到的,
Refresh机制
refresh机制是Spring Cloud Config提供的一种刷新机制,它允许客户端通过POST方法触发各自的/refresh,只要依赖spring-boot-starter-actuator包就拥有了/refresh的功能,下面我们为我们的客户端加上刷新功能,以支持更新配置的读取。
添加依赖
1 | <dependency> |
开启更新机制,在使用配置属性的类型加上 @RefreshScope 注解,这样在客户端执行 /refresh 的时候就会刷新此类下面的配置属性了。
修改配置文件
1 | management: |
http://localhost:9999/actuator/refresh
Spring Cloud Bus
消息总线,它通过轻量级的消息代理来连接各个分布的节点,可以利用像消息队列的广播机制在分布式系统中进行消息传播,通过消息总线可以实现很多业务功能,其中对于配置中心客户端刷新,就是一个非常典型的使用场景。
Spring Cloud Bus 进行配置更新步骤如下:
- 提交代码触发post请求给/actuator/bus-refresh
- server端接收到请求并发送给Spring Cloud Bus
- Spring Cloud bus接到消息并通知给其它客户端
- 其它客户端接收到通知,请求Server端获取最新配置
- 全部客户端均获取到最新的配置
安装rabbitmq
客户端实现
添加依赖
1 | <dependency> |
添加配置1
2
3
4
5
6
7
8
9
10 rabbitmq:
host: localhost
port: 5672
username: guest
password: guest
management:
endpoints:
web:
exposure:
include: "*"
服务端实现
1 | <dependency> |