总线Bus
SpringCloud Bus动态刷新全局广播
根据 3355 新建一个 3366
利用消息总线触发一个服务端 ConfigServer的/bus/refresh端点,而刷新所有客户端的配置:
图二的架构显然更加适合,图一不适合的原因如下:
给服务端3344添加消息总线支持
pom添加:
<!--添加消息总线RabbitMQ的支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
yml添加:
rabbitmq:
host: 10.211.55.17 #本机写localhost,服务器的写服务器地址
port: 5672 #客户端和RabbitMQ进行通信的端口
username: guest #默认也是guest
password: guest #默认也是guest
#RabbitMQ相关配置
management:
endpoints: #暴露bus刷新配置的端点
web:
exposure:
include: 'bus-refresh'
给客户端3355和3366添加消息总线支持
pom添加:
<!--添加消息总线RabbitMQ的支持-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>
yml添加:
rabbitmq:
host: 10.211.55.17 #本机写localhost,服务器的写服务器地址
port: 5672 #客户端和RabbitMQ进行通信的端口
username: guest #默认也是guest
password: guest #默认也是guest
测试
启动7001,3344,3355,3366。
修改GitHub上文件的版本号。
在终端输入:curl -X POST "http://localhost:3344/actuator/bus-refresh"
在浏览器输入http://localhost:3355/configInfo,http://localhost:3366/configInfo
SpringCloud Bus动态刷新定点通知
- 修改GitHub的文件版本号。
- 在终端输入:
curl -X POST "http://localhost:3344/actuator/bus-refresh/config-client:3355"
多加了服务名:端口号即可定点通知。