SpringCloud学习(八)——消息总线Bus

@TOC

消息总线Spring Cloud Bus

在这里插入图片描述

在这里插入图片描述

Spring Cloud Bus能管理和传播分布式系统间的消息,就像一个分布式执行器,可用于广播状态更改、时间推送等。也可以当作微服务间的通信通道。

什么是总线

在微服务架构的系统中,通常会使用轻量级的消息代理来构建一个共用的消息主题,并让系统中所有微服务实例都连接上来。由于该主题产生的消息会被所有实例监听和消费,所以称他为消息总线。

基本原理

ConfigClient实例都监听MQ中同一个topic(默认是springCloudBus),当一个服务刷新数据时,它会把这个消息放入topic中,这样监听同一topic的服务就能得到通知,然后更新自身的配置。

动态刷新全局广播

在这里插入图片描述

全局广播的设计思想

两种设计思路:
在这里插入图片描述第二种更好,第一种不好的原因:

  1. 打破了微服务的职责单一性,因为微服务本身是业务模块,它不应该承担配置刷新的职责
  2. 破坏了微服务各节点的对等性
  3. 有一定的局限性。例如,微服务在迁移时,它的网络地址经常会发生变化,此时如果要想做到 自动刷新,那就会增加更多的修改。
    步骤:
    在这里插入图片描述
  4. 3344、3355、3366端引入rabbitmq依赖,添加消息总线RabbitMQ支持

       <!--添加消息总线RabbitMQ支持-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-bus-amqp</artifactId>
        </dependency>
  1. 3344端配置rabbitmq

测试:
在这里插入图片描述
运维工程师发送
在这里插入图片描述
实现一次发送,出处生效

定点通知

如果只想通知某些主机,而不是全部实例,可以使用定点通知
在这里插入图片描述在这里插入图片描述destination为服务名称:端口号

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值