Rabbitmq的死信队列与如何利用死信队列实现延迟队列

如果设置了队列的 TTL 属性,那么一旦消息过期,就会被队列丢弃(如果配置了死信队列被丢到死信队列中)。而如果仅设置消息的 TTL 属性,即使消息过期,也不一定会被马上丢弃,因为消息是否过期是在即将投递到消费者之前判定的,如果当前队列有严重的消息积压情况,则已过期的消息也许还能存活较长时间;

还需要注意的一点是,如果不设置 TTL,表示消息永远不会过期,如果将 TTL 设置为 0,则表示除非此时可以直接投递该消息到消费者,否则该消息将会被丢弃。

上文中提到的问题,确实是一个问题,如果不能实现在消息粒度上的 TTL,并使其在设置的TTL 时间及时死亡,就无法设计成一个通用的延时队列。那如何解决呢,我们可以通过 Rabbitmq 自带的延时队列插件解决这个问题。

这个就是声明一个延迟交换机实现需求

在我们自定义的交换机中,这是一种新的交换类型,该类型消息支持延迟投递机制 消息传递后并不会立即投递到目标队列中,而是存储在 mnesia(一个分布式数据系统)表中,当达到投递时间时,才投递到目标队列中。

总结:

RabbitMQ 实现延迟队列有两种方式,一种是通过死信来实现,其中又细分为设置队列的TTL和消息的TTL两种,原理就是消息在指定的时间过期后会通过死信交换机进入到死信队列,最后被消费者消费,不过基于消息到TTL来实现会存在消息积压而导致没有在后面发送到消息没有在指定延迟时间被消费的情况,因为该情况本质上是遵循先来先到的原则,先发送的消息延迟时间到了后才继续处理后面的消息;另一种是通过 RabbitMQ 的插件来实现,该插件的原理就是是消息在交换机处延迟,也就是生产者发送消息到延迟交换机等待指定时候才路由到队列中由消费者消费,该方式简单而且能避免上述问题,只需要一个延迟交换机即可实现,不需要死信交换机和死信队列。

相关推荐
蓝宗林3 小时前
Spark 以及 spark streaming 核心原理及实践
大数据·分布式·spark
李明一.3 小时前
Spark 技术与实战学习心得:从入门到实践的深度探索
大数据·分布式·spark
Koma-forever3 小时前
Rabbitmq的五种消息类型介绍,以及集成springboot的使用
spring boot·rabbitmq·java-rabbitmq
计算机毕设定制辅导-无忧学长5 小时前
Kafka 与其他 MQ 的对比分析:RabbitMQ/RocketMQ 选型指南(二)
kafka·rabbitmq·rocketmq
Edingbrugh.南空6 小时前
Kafka性能压测报告撰写
分布式·kafka
lisanmengmeng7 小时前
rabbitMQ 高可用
linux·分布式·rabbitmq
计算机毕设定制辅导-无忧学长7 小时前
Kafka 与其他 MQ 的对比分析:RabbitMQ/RocketMQ 选型指南(一)
kafka·rabbitmq·rocketmq
llwszx7 小时前
分布式锁的四种实现方式:从原理到实践
java·分布式·spring·分布式锁
憶巷7 小时前
TC、TM、RM如何协同解决分布式事务难题
分布式
未来并未来21 小时前
微服务中的分布式事务
分布式·微服务·架构