SpringCloud BUS 消息总线协调微服务配置与服务消息同步
目录
Spring Cloud Bus简介
Spring Cloud config配置中心可以实现配置修改在不重启服务的情况下进行更新,但是每次更新属性还要去一个一个访问接口,太麻烦了,这个时候我们就要象到发布-订阅模型,让所有服务去订阅这个事件(配置文件发生改变),当配置文件改变时,去通知所有服务更新配置,Bus消息总线就可以完成这样的功能。Spring Cloud Bus除了支持RabbitMQ之外,还支持现在被广泛应用的Kafka,本文中使用kafka做消息总线,另外spring boot版本是2.1.3和1.x的版本不同。
我们通常会使用消息代理来构建一个主题,然后把微服务架构中的所有服务都连接到这个主题上去,当我们向该主题发送消息时,所有订阅该主题的服务都会收到消息并进行消费。使用 Spring Cloud Bus 可以方便地构建起这套机制,所以 Spring Cloud Bus 又被称为消息总线。Spring Cloud Bus 配合 Spring Cloud Config 使用可以实现配置的动态刷新。目前 Spring Cloud Bus 支持两种消息代理:RabbitMQ 和 Kafka,下面以 RabbitMQ 为例来演示下使用Spring Cloud Bus 动态刷新配置的功能。
服务间消息同步模型:
下面是config-server和config-clinet配置集成spring cloud bus的过程。
config-server添加消息总线支持
- 在pom.xml中添加相关依赖:
<dependency>
<groupId>org.springframework.cl
纸上得来终觉浅,绝知此事要躬行。