Config+Bus:实现动态刷新

RabbitMQ的安装

背景

Config+Bus:实现动态刷新_第1张图片
如果需要实现修改远端仓库里的配置文件的信息,对应的配置信息的客户端也能动态的刷新配置信息,而不要重新启动程序。那么需要引入消息中间件,我这里使用的是RabbitMQ,还有微服务和RabbitMQ进行通信的Spring Cloud Bus。

我的版本

SpringBoot 2.1.4.RELEASE
SpringCloud Greenwich.SR1

落地实现

Config Server

1.首先修改pom.xml文件,引入相应的依赖


	org.springframework.cloud
	spring-cloud-starter-bus-amqp

2.然到修改配置文件 application.yml
添加的配置信息
2.1首先是和装了RabbitMQ的机器进行连接的配置

spring:
  rabbitmq:
    host: #设置rabbitMQ的客户端的访问端口
    port:#访问端口

2.2:当configs erver和config client都往RabbitMQ发送消息时,还需要 手动地提交一个 /actuator/bus-refresh请求(该请求可以在远程仓库进行设置:当pull配置代码的时候,动态发送请求),所以需要进行一下参数设置,使其暴露该访问的路径,我这里设置了暴露所有的端口了。


management:
  endpoints:
    web:
      exposure:
        include: "*"

3.Config client 端的配置

3.1修改配置pom.xml文件

引入同样的依赖

 
      org.springframework.cloud
         spring-cloud-starter-bus-amqp
  

3.2application.yml

添加的配置信息
RabbitMQ的机器进行连接的配置

spring:
  rabbitmq:
    host: #设置rabbitMQ的客户端的访问端口

测试、

启动服务端和客户端后,访问MQ的页面,可以出页面多出两个队列信息
Config+Bus:实现动态刷新_第2张图片

1.修改仓库中的配置文件;
2.向config server端提交请求:127.0.0.1:8003/actuator/bus-refresh
3.检查配置文件是够动态刷新

你可能感兴趣的:(SpringCloud)