RabbitMQ怎么实现延迟消息?

在RabbitMQ中,实现延迟消息可以通过死信交换机(DLX)+过期时间(TTL)的方案,也可以采用RabbitMQ官方提供的延迟消息插件。

DLX+TTL。

主要步骤如下:

1.声明并创建普通交换机和普通队列,完成二者的绑定。

2.声明并创建死信交换机和死信队列,也完成二者的绑定。

3.指定当前普通队列的死信要转发到哪个DLX,以及要匹配哪个死信路由键。

4.不给普通队列配置任何的消费者,使普通队列只做消息暂存和过期,不消费。

5.在生产者发送消息时,为消息设置TTL,将消息发送到普通队列和普通交换机。

6当消息在普通队列的存活时间达到TTL后,过期的消息会被自动转发到DLX中,DLX再重新路由到死信队列,从死信队列中发送的消息就是延迟消息。

rabbitmq_delayed_message_exchange插件

主要步骤:

1.将插件放到RabbitMQ的plugins目录

2.执行rabbitmq-plugins enable rabbitmq_delayed_message_exchange命令启用插件

3.声明一个延迟交换机

4.声明一个普通队列并绑定该延迟交换机

5.生产者在发送消息时,设置消息投x-dlay:延迟时间(ms)

相关推荐
小北方城市网2 小时前
SpringBoot 集成 RabbitMQ 实战(消息队列解耦与削峰):实现高可靠异步通信
java·spring boot·python·微服务·rabbitmq·java-rabbitmq·数据库架构
装不满的克莱因瓶2 小时前
【2026最新 架构环境安装篇三】Docker安装RabbitMQ4.x详细教程
linux·运维·docker·容器·架构·rabbitmq
Chan166 小时前
【 Java八股文面试 | RabbitMQ篇 】
java·spring boot·spring·面试·java-ee·rabbitmq·java-rabbitmq
小北方城市网8 小时前
SpringBoot 集成 Redis 实战(缓存优化与分布式锁):打造高可用缓存体系与并发控制
java·spring boot·redis·python·缓存·rabbitmq·java-rabbitmq
jonyleek1 天前
告别硬编码:通过逻辑编排引擎的RabbitMQ监听实现灵活自动化
分布式·自动化·rabbitmq·服务编排·逻辑引擎
利刃大大1 天前
【RabbitMQ】延迟队列 && 事务 && 消息分发
分布式·消息队列·rabbitmq·队列
八宝粥大朋友1 天前
rabbitMQ-C 构建android 动态库
android·c语言·rabbitmq
小北方城市网1 天前
SpringBoot 集成消息队列实战(RabbitMQ/Kafka):异步通信与解耦,落地高可靠消息传递
java·spring boot·后端·python·kafka·rabbitmq·java-rabbitmq
九转苍翎1 天前
掌控消息全链路(1)——初识RabbitMQ:从核心概念到五种常用模式全景解析
rabbitmq