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

RabbitMQ的死信队列

1.死信的概念

死信简单理解就是因为种种原因,无法被消费的消息.

有死信自然就有死信队列,消息再一个队列中编程死信之后,它能被重新发送到另一个交换器中,这个交换器就是DLX,绑定DLX的队列,就被称为死信队列,简称DLQ

消息变成死信一般由于一下几种情况:

1.消息被拒绝

2.消息过期

3.队列达到最大长度 

1.2正常队列绑定死信交换机

retrn QueueBuilder.durable(Constant.NORMAL_QUEUE)
 .deadLetterExchange(Constant.DLX_EXCHANGE_NAME)
 .deadLetterRoutingKey("dlx").build();

当这个队列存在死信时,RabbitMQ会自动把这个消息重新发布到设置的DLX上,进而被路由到死信队列上。 

1.3死信队列的应用场景

  • 消息重试:将死信消息重新发送到原队列或另一个队列进行重试处理,比如,在一个支付系统中,支付结果通知消息可能因为网络问题无法被支付回调服务及时消费,那么可以将该消息放入死信队列,稍后再进行重试,直到消费成功。
  • 消息丢弃:直接丢弃这些无法处理的消息,以避免他们占用系统资源
  • 日志收集:将私信消息作为日志收集起来,用于后续分析和问题定位
  • 例如,一个电商系统中,订单处理服务在消费订单消息时,如果因为库存不足无法完成订单处理,那么该订单消息就可以被发送到死信队列中,等待人工介入或者后续的库存补充后再进行处理


http://www.kler.cn/a/393783.html

相关文章:

  • Java Spring Boot实现基于URL + IP访问频率限制
  • 数据集-目标检测系列- 电话 测数据集 call_phone >> DataBall
  • Vue3+Element给表单设置多个验证+规则Rules自定义
  • Babylon.js行为编写及使用参考
  • Figma如何装中文字体-PingFang苹方字体、Alibaba PuHuiTi阿里普惠
  • STM32烧写失败之Contents mismatch at: 0800005CH (Flash=FFH Required=29H) !
  • UE5 HLSL 学习笔记
  • ISP——你可以从这里起步(二)
  • 基于微信小程序的农场管理系统的设计与实现,LW+源码+讲解
  • 通俗易懂:什么是 Java 类加载?
  • 多叉树笔记
  • Linux 如何使用函数删除非空目录
  • Android11 修改系统语言
  • P10901 [蓝桥杯 2024 省 C] 封闭图形个数
  • scala创建图书信息类,包含三个属性:书名,作者,价格
  • Spring Boot框架:电商系统的快速开发
  • arcgis做buffer
  • 学习threejs,使用导入的模型生成粒子
  • 扫雷游戏代码分享(c基础)
  • 观察者模式 vs 不使用观察者模式:商品库存变化的通知
  • Spring框架之责任链模式 (Chain of Responsibility Pattern)
  • GDSC、CTRP数据库学习
  • ApiSmart-QWen2.5 coder vs GPT-4o 那个更强? ApiSmart 测评
  • 使用Java爬虫获取淘宝商品类目API返回值
  • Rust学习(一):初识Rust和Rust环境配置
  • Kafka Eagle 安装教程