【springcloud】使用spring cloud bus实现自动更新配置文件

一、原理

流程图

Spring Cloud Bus做配置更新步骤如下:

  • 1、提交代码,利用 git 的 webhook 触发post请求给 bus/refresh
  • 2、server端接收到请求并发送给Spring Cloud Bus
  • 3、Spring Cloud bus接到消息并通知给其它客户端
  • 4、其它客户端接收到通知,请求Server端获取最新配置
  • 5、全部客户端均获取到最新的配置

二、项目改造

config-server

添加依赖


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

在yml文件中配置rabbitmq的信息和开启访问接口的权限

spring:
  rabbitmq:
    host: 192.168.0.35
    port: 5672
    username: guest
    password: guest
management:
  endpoints:
    web:
      exposure:
        include: "*"

config-client

添加依赖


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

在yml文件中配置rabbitmq的信息

spring:
  rabbitmq:
    host: 192.168.0.35
    port: 5672
    username: guest
    password: guest

到此,server端和client端都已经配置完成,启动两个项目,可以在rabbitmq的管理界面看到多了两个队列

【springcloud】使用spring cloud bus实现自动更新配置文件_第1张图片

在server端启动后,可以在日志中找到访问的接口 /actuator/bus-refresh

【springcloud】使用spring cloud bus实现自动更新配置文件_第2张图片

在git上修改配置文件,然后访问该接口,client端将会自动重新拉取配置。

如果要配置文件变更后自动访问接口,实现自动拉取配置,需要在git的webhook上将接口配置上去即可。

你可能感兴趣的:(springcloud)