书接上文,继续跟着周阳老师学习SpringCloud的消息中心Bus。
Spring Cloud Bus 集成了市面上常用的消息代理(rabbitmq、kafka等 2种),连接微服务系统中的所有节点,当有数据变更时,可以通过消息代理广播通知微服务及时变更数据;例如微服务的配置更新。
Bus 解决了微服务数据变更,及时同步的问题。
Spring cloud bus目前只这次RabbitMQ/Kafka作为消息总线,并没有对ActiveMQ/RokcetMQ做支持。
Bus消息总线的刷新类型有两类,一类是对client整合,通过client接口刷新一个client后,经过bus通知其他的client刷新信息。如下图:
Bus消息总线刷新类型第二种是通知统一配置管理中心,将由统一配置管理中心通知bus,然后告诉其他的微服务获取配置信息。如下图:
设计原理:
ConfigBus实例监听MQ中同一个topic(默认是springCloudBus).当一个服务刷新数据的时候,它会把这个消息放入到Topic中,这样其他监听同一个Topic的服务就能得到通知,然后去更新自身的配置;
设计思想:
1)利用消息总线触发一个客户端/bus/refresh,而刷新所有客户端的配置:破环微服务单一性,对等性;
2)利用消息总线触发一个服务端ConfigServer的/bus/fresh端点,而刷新所有客户端的配置;
搭建过程请自行谷歌、百度
双击RabbitMQ service start
浏览器输入:localhost:15672 ,输入账号和密码:guest、guest 可以看到RabbitMQ的主界面
bootstrap.yml
server: port: 3366 spring: application: name: config-client cloud: config: label: master name: config profile: dev uri: http://localhost:3344 #15672是管理界面端口,5672是MQ访问的端口 rabbitmq: host: localhost port: 5672 username: guest password: guest eureka: client: service-url: defaultZone: http://localhost:7001/eureka # 暴露监控端点 management: endpoints: web: exposure: include: "*"
ConfigClientMain3366
@SpringBootApplication @EnableEurekaClient public class ConfigClientMain3366 { /*消息总线: 微服务中使用轻量级消息代理来构建一个共用的消息主题,并让微服务系统中所有实例都连接上来。 *由于该主题中产生的消息会被所有实例监听和消费,所以称为消息总线。 *在总线上个各个实例,都可以广播一些需要其他连接到该主题上的实例都知道的消息 * * 基本原理: * ConfigClient实例都监听MQ中同一个topic(默认是SpringCloudBus),当一个服务刷新数据时,会把这个信息放到topic * ,这样其他监听到同一个topic服务就能得到通知,然后去更新自身的配置。 */ //利用消息总线,触发一个服务器端ConfigServer的bus/refresh端点,而刷新所有客户端的配置,总的来说就是:实现自动刷新配置功能 //用3344作为Server,通知3355、3366两个Client public static void main(String[] args) { SpringApplication.run(ConfigClientMain3366.class, args); } }
ConfigClientController
@RestController @RefreshScope public class ConfigClientController { @Value("${server.port}") private String serverPort; @Value("${config.info}") private String configInfo; @GetMapping("/configInfo") public String configInfo(){ return "serverPort: " +serverPort+ "\t\n\n configInfo: "+ configInfo; } }
3355、3366yml新增:
rabbitmq: #rabbitmq相关配置,15672是web管理端口,5672是mq访问端口 port: 5672 host: localhost username: guest password: guest #暴露监控端点 management: endpoints: web: exposure: include: "*"
1、修改Gitee中config-dev.yml版本号
2、cmd 刷新3344
cmd窗口中执行
curl -X POST "http://localhost:3344/actuator/bus-refresh"
结果:3355、3366 都已经改变,一次修改、广播通知、到处运行。
上面是全局通知,但如果我们想定点通知该如何做呢?
定点通知:只通知3355,不通知3366
实现方法:cmd 刷新3344
curl -X POST "http://localhost:3344/actuator/bus-refresh/config-client:3355"