news 2026/3/11 2:52:44

【面试题】RabbitMQ 中无法路由的消息会去到哪里?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【面试题】RabbitMQ 中无法路由的消息会去到哪里?

在 RabbitMQ 中,无法路由的消息(即交换机无法将消息路由到任何队列)的处理方式取决于消息发布时的参数配置,主要有以下几种情况:

1. 普通情况(默认行为)

如果消息发布时没有设置特殊参数:

/* by yours.tools - online tools website : yours.tools/zh/blood.html */ // 默认情况:无法路由的消息直接被丢弃 channel.basicPublish( "my-exchange", // 交换机名称 "routing-key", // 路由键 null, // 消息属性(没有设置mandatory) messageBody // 消息体 );

结果:消息被静默丢弃,生产者不会收到任何通知。


2. 使用mandatory参数

当设置mandatory=true时:

/* by yours.tools - online tools website : yours.tools/zh/blood.html */ channel.basicPublish( "my-exchange", "unroutable-key", { mandatory: true }, // 关键参数 messageBody ); // 添加返回监听器 channel.addReturnListener((returnMessage) => { console.log("消息无法路由被返回:", { replyCode: returnMessage.replyCode, replyText: returnMessage.replyText, exchange: returnMessage.exchange, routingKey: returnMessage.routingKey, body: returnMessage.body.toString() }); });

结果

  • 消息无法路由时,会通过Basic.Return命令返回给生产者
  • 生产者可以监听并处理这些返回的消息
  • 这是推荐的可靠消息发布方式

3. 使用备用交换器(Alternate Exchange,AE)

这是处理无法路由消息的最佳实践

// 1. 首先声明一个备用交换器(通常是一个Fanout类型) channel.assertExchange("my-ae", "fanout", { durable: true }); channel.assertQueue("unroutable-messages", { durable: true }); channel.bindQueue("unroutable-messages", "my-ae", ""); // 2. 声明主交换器时指定备用交换器 const args = { "alternate-exchange": "my-ae" }; channel.assertExchange("my-direct-exchange", "direct", { durable: true, arguments: args // 设置备用交换器 });

工作原理

发布消息 → 主交换器无法路由 → 自动转发到备用交换器 → 备用交换器路由到专用队列

优点

  • 无需生产者设置mandatory
  • 所有无法路由的消息都被集中收集
  • 可以后续分析、重试或人工处理

4. 与死信交换器(DLX)的区别

重要区分:无法路由的消息不会进入死信队列(DLQ),除非:

  1. 使用备用交换器将消息路由到队列
  2. 该队列配置了死信交换器
  3. 消息在该队列中过期或被拒绝
特性无法路由的消息死信消息
触发时机交换机找不到匹配队列消息在队列中被拒绝、TTL过期、队列超限
处理方式丢弃/返回/备用交换器转发到死信交换器
配置位置交换器级别队列级别

5. 实际工作流程示例

场景:订单系统

// 配置备用交换器收集无法路由的订单消息 channel.assertExchange("orders-ae", "fanout", { durable: true }); channel.assertQueue("dead-letters.orders", { durable: true }); channel.bindQueue("dead-letters.orders", "orders-ae", ""); // 主交换器 const args = { "alternate-exchange": "orders-ae" }; channel.assertExchange("orders", "direct", { durable: true, arguments: args }); // 正常队列 channel.assertQueue("orders.process", { durable: true }); channel.bindQueue("orders.process", "orders", "order.created"); // 生产者发布消息 // 如果路由键是 "order.updated"(没有队列绑定) // 消息会进入 dead-letters.orders 队列

6. 最佳实践建议

  1. 生产环境必选方案

    方案一(推荐): 启用备用交换器 + 监控无法路由消息队列 方案二: 设置 mandatory=true + 实现ReturnListener
  2. 监控和告警

    // 监控无法路由消息队列的长度 channel.assertQueue("unroutable-messages", { durable: true }); // 定期检查队列消息数 const result = channel.checkQueue("unroutable-messages"); if (result.messageCount > threshold) { sendAlert("发现大量无法路由的消息!"); }
  3. 常见原因分析

    • 路由键拼写错误
    • 消费者队列未正确绑定
    • 交换器类型与路由规则不匹配
    • 动态路由键生成逻辑错误

总结

RabbitMQ 中无法路由的消息有三条可能的路径:

  1. 默认:静默丢弃(不推荐)
  2. 通过mandatory=true:返回给生产者处理
  3. 通过备用交换器:集中收集到专门队列(最佳实践)

推荐架构

生产者 → 主交换器(配置备用交换器) ↓(无法路由) 备用交换器(Fanout) ↓ "unroutable.messages"队列 ↓ 监控系统/人工处理

这样既能保证消息不丢失,又能及时发现路由配置问题。

❤️ 如果你喜欢这篇文章,请点赞支持! 👍 同时欢迎关注我的博客,获取更多精彩内容!

本文来自博客园,作者:佛祖让我来巡山,转载请注明原文链接:https://www.cnblogs.com/sun-10387834/p/19388747

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/11 2:52:30

面向公务员考试的考公考编刷题小程序 考公考编

目录 考公考编刷题小程序的功能与优势用户体验与个性化服务技术特点与市场价值 项目技术支持论文大纲核心代码部分展示可定制开发之亮点部门介绍结论源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作 考公考编刷题小程序的功能与优势 考公考…

作者头像 李华
网站建设 2026/3/11 2:52:16

Cowabunga Lite:无需越狱实现iOS深度个性化定制的完整指南

Cowabunga Lite:无需越狱实现iOS深度个性化定制的完整指南 【免费下载链接】CowabungaLite iOS 15 Customization Toolbox 项目地址: https://gitcode.com/gh_mirrors/co/CowabungaLite 厌倦了iPhone千篇一律的界面?Cowabunga Lite为你带来革命性…

作者头像 李华
网站建设 2026/3/11 2:52:02

反向海淘的奇葩好物:这些东西居然也能寄出国?

近几年“海淘”大家都不陌生:从国外买回来、清关、转运、等快递。更有意思的是,另一股反向潮流也悄悄起来了——反向海淘:把国内的东西寄到国外给朋友、同事、客户,或者海外的自己(留学/工作/旅居)用。 很多…

作者头像 李华
网站建设 2026/3/10 16:37:05

反向海淘上瘾是种什么体验?海外党戒不掉的国货

反向海淘上瘾是种什么体验?海外党戒不掉的国货 人在海外久了,你会发现一个很现实的规律: “想省钱”很难,“想省心”更难。 最先让人破防的,往往不是房租和税,而是一些在国内随手就能买到的小东西——到了国…

作者头像 李华
网站建设 2026/3/7 5:36:27

10款降AIGC率网站免费功能实测,排行榜及用户评价综合对比

降AIGC率网站排行榜:10大平台免费功能实测 核心工具对比速览 排名 工具名称 降重效率 特色功能 适用场景 1 aicheck ⚡⚡⚡⚡⚡ 专业术语保留 高重复率论文急救 2 秒篇 ⚡⚡⚡⚡ 逻辑结构优化 社科类论文 3 askpaper ⚡⚡⚡⚡ 多轮迭代降重 理工…

作者头像 李华
网站建设 2026/3/9 14:48:51

智能文献管理革命:5大黑科技让你的学术效率翻倍

智能文献管理革命:5大黑科技让你的学术效率翻倍 【免费下载链接】zotero-style zotero-style - 一个 Zotero 插件,提供了一系列功能来增强 Zotero 的用户体验,如阅读进度可视化和标签管理,适合研究人员和学者。 项目地址: https…

作者头像 李华