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

【RabbitMQ】- Channel和Delivery Tag机制

在 RabbitMQ 的消费者代码中,Channel 和 tag 参数的存在是为了实现消息确认机制(Acknowledgment)和精细化的消息控制。

Channel 参数

作用

Channel 是 AMQP 协议的核心操作接口,通过它可以直接与 RabbitMQ 交互:

  • 手动消息确认:通过 basicAck/basicNack 显式告知 RabbitMQ 消息处理结果
  • 流量控制:可调用 basicQos 限制预取消息数量(防止消费者过载)
  • 其他高级操作:如消息重发、队列绑定等

如果不传入 Channel,Spring AMQP 会自动使用默认信道,但会失去对信道的直接控制权。

对应原理

在这里插入图片描述
在这里插入图片描述

生产者的 Channel

  • 当生产者调用 rabbitTemplate.convertAndSend() 时:
rabbitTemplate.convertAndSend("doctor.queue", jsonMessage);
  • Spring AMQP 内部会从 连接池 获取一个 Channel(信道)。
  • Channel 用于将消息发布到指定队列。
  • 发布后自动关闭(如果是非事务模式)或复用。

消费者的 Channel

  • 消费者通过 @RabbitListener 监听队列时:
@RabbitListener(queues = "doctor.queue")
public void onMessage(String json, Channel channel, @Header(AmqpHeaders.DELIVERY_TAG) long tag) {// 处理逻辑
}
  • Spring AMQP 会为每个消费者线程分配一个 独立的 Channel
  • 所有消息的确认(ACK/NACK)必须通过 同一个 Channel 操作(否则会报错)。

tag 参数

作用

@Header(AmqpHeaders.DELIVERY_TAG) 注入的 tag 是消息的唯一标识符:

  • 消息指纹:每个投递给消费者的消息都会获得唯一的 delivery tag
  • 幂等性设计:通过 tag 可以精确确认/拒绝特定消息
  • 必须参数:调用 basicAck/basicNack 时必须指定此 tag

Tag 的数值范围仅在当前信道内唯一,不同信道的 tag 可能重复。

对应原理

Tag 的生成

  • 当 RabbitMQ 将消息推送给消费者时:
    • 服务端会为 每条消息 分配一个唯一的 Delivery Tag(在当前 Channel 内递增)。
    • 例如:第一次推送的 Tag=1,第二次 Tag=2,…(不同 Channel 的 Tag 独立计数)。

Tag 的作用

  • 唯一标识消息:消费者通过 Tag 告诉 RabbitMQ 要确认/拒绝哪条消息。
  channel.basicAck(tag, false); // 确认当前消息channel.basicNack(tag, false, true); // 拒绝并重新入队
  • 严格顺序性:Tag 在同一个 Channel 内严格递增,确保消息顺序处理。
  • RabbitMQ 服务端维护了一个 消息投递状态表,记录每个 Channel 的 Tag 对应哪条消息。
  • 当消费者发送 ACK/NACK 时,RabbitMQ 根据 Channel + Tag 组合定位到原始消息。

手动确认模式

手动确认模式的优点:

  • 可靠性:只有处理成功的消息才会被确认(basicAck
  • 错误恢复:处理失败时通过 basicNack 让消息重新入队
  • 业务控制:可以根据业务逻辑决定是否确认(如示例中的 shouldBeProcessed 判断)
// 成功处理 - 确认删除
channel.basicAck(tag, false); // 处理失败 - 拒绝并重新入队
channel.basicNack(tag, false, true);

工作流程

在这里插入图片描述

http://www.lqws.cn/news/98515.html

相关文章:

  • 『React』组件副作用,useEffect讲解
  • 灵活运用 NextJS 服务端组件与客户端组件
  • Dify:启动 Web 服务的详细指南
  • CSS 平铺+自动换行效果
  • IT运维工具推荐
  • Web前端为什么要打包?Webpack 和 Vite 如何助力现代开发?
  • 统信 UOS 服务器版离线部署 DeepSeek 攻略
  • vue-14(使用 ‘router.push‘ 和 ‘router.replace‘ 进行编程导航)
  • 芒果深度学习检测:开启农业新视界(猫脸码客第230期)
  • CentOS Stream 8 Unit network.service not found
  • 美尔斯通携手北京康复辅具技术中心开展公益活动,科技赋能助力银龄健康管理
  • dvwa5——File Upload
  • 智能氮气柜的发展历程和前景展望
  • 星野录(博客系统)测试报告
  • 从“Bucharest”谈起:词语翻译的音译与意译之路
  • 项目任务,修改svip用户的存储空间。
  • 帝可得 - 设备管理
  • Spring中@Controller和@RestControlle注解的区别
  • Spring AI Advisor机制
  • 用 Vue 做一个轻量离线的“待办清单 + 情绪打卡”小工具
  • LangChain实战:文档加载、分割与向量存储详解
  • Linux或者Windows下PHP版本查看方法总结
  • 浅谈机械硬盘存储技术与磁盘格式化
  • ORA-12899: value too large for column LONG_TYPE (actual: 30, maximum: 20)
  • 谷歌地图高清卫星地图2026中文版下载|谷歌地图3D卫星高清版 V7.3.6.9796 最新免费版下载 - 前端工具导航
  • UniRig:如何在矩池云一站式解决 3D 模型绑定难题
  • Flink03-学习-套接字分词流自动写入工具
  • 剑指offer14_二进制中1的个数
  • 用HTML5 Canvas打造交互式心形粒子动画:从基础到优化实战
  • 链表题解——反转链表【LeetCode】