Spring Cloud教程 第十二弹 Spring Cloud Config整合Spring Cloud Bus实现配置动态刷新
admin
2024-04-15 13:14:35

Spring Cloud Config整合Spring Cloud Bus

  • 1、回顾
  • 2、手动刷新
  • 3、Spring Cloud Bus动态刷新配置

1、回顾

在上一弹:Spring Cloud教程 第十一弹 Spring Cloud Config连接git和数据库 中介绍了spring cloud config的基本使用,但是配置无法动态刷新,也就是说如果我更改了git或数据库中的配置,项目必须重新启动才能使新配置生效。

注意:

  • 更新配置后,调用config server的HTTP接口是可以获取到新配置的,这是因为config server会实时请求git或数据库,配置当然是最新的,但是config client是感知不到的

下面介绍两种不重启项目便可以刷新配置的方式:

  1. 手动刷新
  2. 整合Spring Cloud Bus实现动态刷新

2、手动刷新

步骤如下。

  1. config client项目的pom.xml中引入spring-boot-starter-actuator依赖,如下所示:
org.springframework.bootspring-boot-starter-actuator

  1. config client配置端点,如下所示:
management:endpoints:web:exposure:include: "*"
  1. 在需要动态刷新的Bean上打@RefreshScope,如下所示:
import org.springframework.beans.factory.annotation.Value;
import org.springframework.cloud.context.config.annotation.RefreshScope;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;@RestController
@RefreshScope
public class DynamicRefreshController {@Value("${stuName:\"\"}")private String stuName;@GetMapping("/config")public void init(){System.out.println("stuName="+stuName);}
}
  1. 当修改git、数据库配置时,POST请求config client路径/actuator/refresh,即可手动刷新

3、Spring Cloud Bus动态刷新配置

Spring Cloud Bus 实现配置的动态刷新步骤:

  1. 当git中的配置发生改变后,向config server发送一个 POST请求,请求路径为/actuator/bus-refresh
  2. config server接收到请求后,会将该请求转发给服务总线Spring Cloud Bus
  3. Spring Cloud Bus接到消息后,生成Topic然后会通知给所有config client
  4. config client接收到通知,请求config server拉取最新配置

Spring Cloud Bus需要引入RabbitMQ或Kafka作为消息传输的媒介。

与手动刷新不同,动态刷新的改造主要在config server项目中。

步骤如下:

  1. config server项目中的pom.xml引入依赖,如下所示:
org.springframework.cloudspring-cloud-starter-bus-amqp

org.springframework.bootspring-boot-starter-actuator

  1. config server配置端点,如下所示:
management:endpoints:web:exposure:include: "*"
  1. 安装并运行RabbitMQ
    参考文章:RabbitMQ入门教程
  2. config server配置RabbitMQ
spring:rabbitmq:host: localhostport: 5672username: guestpassword: guest

5.config client引入依赖:

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

  1. config client配置RabbitMQ
spring:rabbitmq:host: localhostport: 5672username: guestpassword: guest

bus-refresh端点原理:

  • /actuator/bus-refresh端点清除RefreshScope缓存并且重新绑定@ConfigurationProperties

相关内容

热门资讯

原创 肝... 老话说“肝藏血,血舍魂”。 肝血就像身体的“充电宝”,白天消耗,晚上靠它修复。 血足了,魂才能安稳归...
吉林长春:冰天雪地欢乐多 本文转自:人民网在长春肆季南河岸线公园,由270个雪雕组成的“雪人方队”吸引着市民游客前来观赏。人民...
“热”涌岗什卡   1月1日,登山爱好者在攀登岗什卡雪峰 岗什卡雪山,位于青海省海北藏族自治州门源回族自治县,是祁连...
东北逛吃超快乐 这游戏的“烟火... “零下20度的街头,咬一口冻梨,冰碴子在嘴里咔嚓响;转身钻进暖烘烘的小馆子,锅包肉刚端上来,糖醋汁还...
黑钻会员吐槽携程服务越来越拉胯... 近日一名网友发帖称,携程黑钻服务真的越来越拉胯了。 该网友表示,定了三张商务舱机票,宽体机变窄体机,...