SpringAMQP - 发布订阅模式
创始人
2024-05-14 04:34:28
0

目录

发布订阅介绍

FanoutExchange简介

FanoutExchange案例

常见小问题

DirectExchange简介

DirectExchange案例

常见小问题

TopicExchange简介

TopicExchange案例


  • 发布订阅介绍

  • 发布(Publish)、订阅(Subscribe)
  • 发布订阅模式与之前案例的区别就是允许将同一消息发送给多个消费者
  • 实现方式是加入了exchange(交换机)
  • Exchange:交换机
  • 一方面,接收生产者发送的消息
  • 另一方面,知道如何处理消息
  • 例如递交给某个特别队列、递交给所有队列、或是将消息丢弃
  • 到底如何操作,取决于Exchange的类型
  • 常见exchange类型包括:
    • Fanout:广播,将消息交给所有绑定到交换机的队列
    • Direct:路由,把消息交给符合指定routing key 的队列
    • Topic:话题,把消息交给符合routing pattern的队列
  • 注意:exchange负责消息路由,而不是存储,路由失败则消息丢失
  • FanoutExchange简介

  • 在广播模式下,消息发送流程是这样的:
    • 可以有多个队列
    • 每个队列都要绑定到 Exchange(交换机)
    • 生产者发送的消息,只能发送到交换机,交换机来决定要发给哪个队列,生产者无法决定
    • 交换机把消息发送给绑定过的所有队列
    • 订阅队列的消费者都能拿到消息
  • FanoutExchange案例

  • 利用SpringAMQP演示FanoutExchange的使用
  • 实现思路如下:
  • 1.在consumer服务中,利用代码声明队列、交换机,并将两者绑定
  • 2.在consumer服务中,编写两个消费者方法,分别监听fanout.queue1和fanout.queue2
  • 3.在publisher中编写测试方法,向icpc.fanout发送消息
  • 步骤1:在consumer服务声明Exchange、Queue、Binding
  • 步骤2:在consumer服务声明两个消费者
  • 在consumer服务的SpringRabbitListener类中添加两个方法
  • 分别监听fanout.queue1和fanout.queue2

  • 步骤3:在publisher服务发送消息到FanoutExchange
  • 在publisher服务的SpringAmqpTest类中添加测试方法

  • 测试成功

  • 常见小问题

  • 交换机的作用是什么?
    • 接收publisher发送的消息
    • 将消息按照规则路由到与之绑定的队列
    • 不能缓存消息,路由失败,消息丢失
    • FanoutExchange的会将消息路由到每个绑定的队列
  • 声明队列、交换机、绑定关系的Bean是什么?
    • Queue
    • FanoutExchange
    • Binding
  • DirectExchange简介

  • 在Fanout模式中,一条消息,会被所有订阅的队列都消费
  • 但是,在某些场景下,我们希望不同的消息被不同的队列消费
  • 这时就要用到Direct类型的Exchange
  • Direct Exchange 会将接收到的消息根据规则路由到指定的Queue,因此称为路由模式(routes)
  • 在Direct模型下:
    • 队列与交换机的绑定,不能是任意绑定了,而是要指定一个RoutingKey(路由key)
    • 消息的发送方在向 Exchange 发送消息时,也必须指定消息的 RoutingKey
    • Exchange不再把消息交给每一个绑定的队列,而是根据消息的Routing Key进行判断,只有队列的Routingkey与消息的 Routing key 完全一致,才会接收到消息
  • DirectExchange案例

  • 利用SpringAMQP演示DirectExchange的使用
  • 实现思路如下:
  • 1.利用@RabbitListener声明Exchange、Queue、RoutingKey
  • 2.在consumer服务中,编写两个消费者方法,分别监听direct.queue1和direct.queue2
  • 3.在publisher中编写测试方法,向icpc.direct发送消息
  • 步骤1:在consumer服务声明Exchange、Queue
  • 1.在consumer服务中,编写两个消费者方法,分别监听direct.queue1和direct.queue2
  • 2.并利用@RabbitListener声明Exchange、Queue、RoutingKey
  • 步骤2:在publisher服务发送消息到DirectExchange
  • 在publisher服务的SpringAmqpTest类中添加测试方法:

  • 测试成功

  • 常见小问题

  • 描述下Direct交换机与Fanout交换机的差异?
    • Fanout交换机将消息路由给每一个与之绑定的队列
    • Direct交换机根据RoutingKey判断路由给哪个队列
    • 如果多个队列具有相同的RoutingKey,则与Fanout功能类似
  • 基于@RabbitListener注解声明队列和交换机有哪些常见注解?
    • @Queue
    • @Exchange
  • TopicExchange简介

  • Topic类型的Exchange与Direct相比
  • 都是可以根据RoutingKey把消息路由到不同的队列
  • 只不过Topic类型Exchange可以让队列在绑定Routing key 的时候使用通配符
  • #:匹配一个或多个词
  • *:匹配1个词
  • 举例:
  • icpc.#:能够匹配icpc.spu.insert 或者 icpc.spu
  • icpc.*:只能匹配icpc.spu
  • TopicExchange案例

  • 利用SpringAMQP演示TopicExchange的使用
  • 实现思路如下:
  • 1.并利用@RabbitListener声明Exchange、Queue、RoutingKey
  • 2.在consumer服务中,编写两个消费者方法,分别监听topic.queue1和topic.queue2
  • 3.在publisher中编写测试方法,向icpc.topic发送消息
  • 步骤1:在consumer服务声明Exchange、Queue
  • 1.在consumer服务中,编写两个消费者方法,分别监听topic.queue1和topic.queue2
  • 2.并利用@RabbitListener声明Exchange、Queue、RoutingKey
  • 步骤2:在publisher服务发送消息到TopicExchange
  • 在publisher服务的SpringAmqpTest类中添加测试方法:

  • 测试成功

相关内容

热门资讯

【NI Multisim 14...   目录 序言 一、工具栏 🍊1.“标准”工具栏 🍊 2.视图工具...
银河麒麟V10SP1高级服务器... 银河麒麟高级服务器操作系统简介: 银河麒麟高级服务器操作系统V10是针对企业级关键业务...
不能访问光猫的的管理页面 光猫是现代家庭宽带网络的重要组成部分,它可以提供高速稳定的网络连接。但是,有时候我们会遇到不能访问光...
AWSECS:访问外部网络时出... 如果您在AWS ECS中部署了应用程序,并且该应用程序需要访问外部网络,但是无法正常访问,可能是因为...
Android|无法访问或保存... 这个问题可能是由于权限设置不正确导致的。您需要在应用程序清单文件中添加以下代码来请求适当的权限:此外...
北信源内网安全管理卸载 北信源内网安全管理是一款网络安全管理软件,主要用于保护内网安全。在日常使用过程中,卸载该软件是一种常...
AWSElasticBeans... 在Dockerfile中手动配置nginx反向代理。例如,在Dockerfile中添加以下代码:FR...
AsusVivobook无法开... 首先,我们可以尝试重置BIOS(Basic Input/Output System)来解决这个问题。...
ASM贪吃蛇游戏-解决错误的问... 要解决ASM贪吃蛇游戏中的错误问题,你可以按照以下步骤进行:首先,确定错误的具体表现和问题所在。在贪...
月入8000+的steam搬砖... 大家好,我是阿阳 今天要给大家介绍的是 steam 游戏搬砖项目,目前...