RabbitMQ的死信队列

1.死信的概念

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

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

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

1.消息被拒绝

2.消息过期

3.队列达到最大长度

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

java 复制代码
retrn QueueBuilder.durable(Constant.NORMAL_QUEUE)
 .deadLetterExchange(Constant.DLX_EXCHANGE_NAME)
 .deadLetterRoutingKey("dlx").build();

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

1.3死信队列的应用场景

  • 消息重试:将死信消息重新发送到原队列或另一个队列进行重试处理,比如,在一个支付系统中,支付结果通知消息可能因为网络问题无法被支付回调服务及时消费,那么可以将该消息放入死信队列,稍后再进行重试,直到消费成功。
  • 消息丢弃:直接丢弃这些无法处理的消息,以避免他们占用系统资源
  • 日志收集:将私信消息作为日志收集起来,用于后续分析和问题定位
  • 例如,一个电商系统中,订单处理服务在消费订单消息时,如果因为库存不足无法完成订单处理,那么该订单消息就可以被发送到死信队列中,等待人工介入或者后续的库存补充后再进行处理
相关推荐
阿巴~阿巴~几秒前
C_数据结构(单链表算法题) —— 相交链表、环形链表I、环形链表II、随机链表的复制
c语言·开发语言·数据结构·算法·链表·1024程序员节
神奇夜光杯4 分钟前
Python酷库之旅-第三方库Pandas(208)
开发语言·人工智能·python·excel·pandas·标准库及第三方库·学习与成长
斗-匕12 分钟前
Spring & Spring Boot 常用注解总结
java·spring boot·spring
夏微凉.14 分钟前
【JavaEE进阶】Spring 事务和事务传播机制
java·数据库·sql·mysql·spring·java-ee
yangpipi-14 分钟前
数据结构(C语言版)-2.栈和队列
c语言·开发语言·数据结构
还在学习进步17 分钟前
C语言第九周课——经典算法
c语言·开发语言·算法
吴冰_hogan18 分钟前
nacos集群源码解析-cp架构
java·spring boot·spring·架构·服务发现·springcloud
阿七想学习19 分钟前
数据结构《链表》
java·开发语言·数据结构·学习·链表
Yaml419 分钟前
Java的六大排序
java·算法·排序算法
极客代码21 分钟前
【Python TensorFlow】进阶指南(续篇二)
开发语言·人工智能·python·深度学习·tensorflow