当前位置: 首页 > news >正文

RabbitMQ之基于注解声明队列交换机:使用@RabbitListener实现消息监听

文章目录

    • 什么是`@RabbitListener`?
    • 队列和交换机的基本概念
    • 使用`@RabbitListener`注解声明队列和交换机
      • 代码解析
        • 1. `@QueueBinding`
        • 2. 消费者方法
    • 运行原理
    • 应用场景
    • 总结

在现代的微服务架构中,消息队列是一种重要的异步通信机制。RabbitMQ作为一种流行的消息代理软件,提供了丰富的功能来处理消息的发布和订阅。在Spring Boot应用中,我们可以使用Spring AMQP提供的注解来简化RabbitMQ的配置和使用。本文将介绍如何使用 @RabbitListener注解来声明队列和交换机,并实现消息监听。

什么是@RabbitListener

@RabbitListener是Spring AMQP框架提供的一个注解,用于定义一个方法,该方法可以监听指定的队列,并在接收到消息时自动调用。通过这种方式,我们可以非常方便地实现消息的异步处理。

队列和交换机的基本概念

在RabbitMQ中,消息的传递依赖于两个核心组件:队列交换机

  • 队列(Queue):用来存储消息,消费者可以从队列中读取消息。
  • 交换机(Exchange):负责接收生产者发送的消息,并根据绑定的规则将消息路由到一个或多个队列。

常见的交换机类型有:

  • Direct:根据消息的路由键(routing key)精确匹配队列。
  • Topic:根据路由键的模式匹配队列。
  • Fanout:将消息广播到所有绑定的队列。

使用@RabbitListener注解声明队列和交换机

下面我们通过一个具体的例子来展示如何使用@RabbitListener注解来声明队列和交换机。

@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "direct.queue1", durable = "true"),exchange = @Exchange(name = "hmall.direct", type = ExchangeTypes.DIRECT),key = {"red", "blue"}
))
public void listenDirectQueue1(String message) {log.info("消费者1监听到direct.queue1消息:{}", message);
}@RabbitListener(bindings = @QueueBinding(value = @Queue(name = "direct.queue2", durable = "true"),exchange = @Exchange(name = "hmall.direct", type = ExchangeTypes.DIRECT),key = {"red", "yellow"}
))
public void listenDirectQueue2(String message) {log.info("消费者2监听到direct.queue2消息:{}", message);
}

代码解析

1. @QueueBinding

@QueueBinding用于绑定队列和交换机,并指定路由键。它包含以下几个属性:

  • value:声明一个队列,使用@Queue注解。

    • name:队列名称,如direct.queue1direct.queue2
    • durable:是否持久化队列。设置为true表示消息队列重启后依然存在。
  • exchange:声明一个交换机,使用@Exchange注解。

    • name:交换机名称,如hmall.direct
    • type:交换机类型,这里使用ExchangeTypes.DIRECT表示Direct交换机。
  • key:路由键数组,指定消息匹配的路由键。如direct.queue1监听redblue两个路由键的消息。

2. 消费者方法
  • listenDirectQueue1:监听direct.queue1,当队列接收到符合路由键redblue的消息时,方法被调用,输出日志信息。
  • listenDirectQueue2:监听direct.queue2,当队列接收到符合路由键redyellow的消息时,方法被调用,输出日志信息。

运行原理

在上述代码中,我们定义了两个消费者,它们分别监听不同的队列,并根据路由键进行消息的分发。

  • hmall.direct是一个Direct类型的交换机,它将消息路由到绑定的队列中。
  • 如果发送的消息的路由键是red,则两个消费者都会接收到该消息。
  • 如果路由键是blue,只有listenDirectQueue1会接收到消息。
  • 如果路由键是yellow,只有listenDirectQueue2会接收到消息。

应用场景

这种基于注解的方式非常适合以下场景:

  1. 简单易用:不需要额外的XML或配置文件,直接在Java代码中完成队列和交换机的声明。
  2. 灵活性高:可以根据需求灵活调整队列和交换机的绑定关系。
  3. 快速开发:减少了手动配置的复杂度,加快开发速度。

总结

通过使用@RabbitListener注解,我们可以方便地在Spring Boot应用中实现RabbitMQ的消息监听和处理。它不仅简化了配置流程,还增强了代码的可读性和可维护性。在实际项目中,我们可以根据业务需求,灵活定义队列、交换机及其绑定关系,实现复杂的消息路由逻辑。

http://www.lryc.cn/news/418068.html

相关文章:

  • 【grafana 】mac端grafana配置的文件 grafana.ini 及login
  • 程序员如何在人工智能时代保持核心竞争力
  • 回溯排列+棋盘问题篇--代码随想录算法训练营第二十三天| 46.全排列,47.全排列 II,51. N皇后,37. 解数独
  • ESXI加入VMware现有集群提示常规性错误
  • 数字噪音计(声级计)【AR814数字噪音计】
  • 【Vue3】图片未加载成功前占位
  • AbstractQueuedSynchronizer之AQS
  • <数据集>起重机识别数据集<目标检测>
  • 04--Docker
  • MiniCPM-V: A GPT-4V Level MLLM on Your Phone 手机上的 GPT-4V 级多模态大模型
  • Unity初识
  • 【游戏引擎之路】登神长阶(九)——《3D游戏编程大师技巧》:我想成为游戏之神!
  • Linux:线程同步之信号量
  • GPT-SoVITS-文本转语音(你的声音不再是唯一)
  • C语言深度剖析(部分)--剩下随缘更新
  • 计算机毕业设计选题推荐-电缆行业生产管理系统-Java/Python项目实战
  • Linux 下查看 CPU 使用率
  • 数理基础知识
  • Java解决lombok和mapstruct编译模块的问题
  • 大模型场景应用全集:持续更新中
  • 理解RabbitMQ中的消息存储机制:非持久化、持久化与惰性队列(Lazy Queue)
  • 【机器学习】BP神经网络正向计算
  • 谷粒商城实战笔记-108~109-elasticsearch删除与批量导入
  • RabbitMQ:发送者的可靠性之使用消息确认回调
  • HCIP学习 | OSPF---LSA限制、不规则区域、附录E、选路
  • CVE-2017-15715~Apache解析漏洞【春秋云境靶场渗透】
  • thinkphp 5.0.24生成模块
  • 值得注意!家里有带毛发动物就有浮毛?宠物空气净化器一键净化
  • Linux 代理(proxy)设置
  • 操作系统真相还原:获取文件属性