Config+Bus:实现动态刷新

RabbitMQ的安装

背景

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

落地实现

Config Server

1.pom.xml

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-bus-amqp</artifactId>
</dependency>

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

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

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


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

Config client

修改配置pom.xml文件
引入依赖

 <dependency>
      <groupId>org.springframework.cloud</groupId>
         <artifactId>spring-cloud-starter-bus-amqp</artifactId>
  </dependency>

application.yml

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

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

测试、

启动服务端和客户端后
这里写图片描述

1.修改配置文件
2.提交请求:127.0.0.1:8003/actuator/bus-refresh
3.检查配置文件是够动态刷新

猜你喜欢

转载自blog.csdn.net/ycd500756/article/details/81006162