通过RabbitMQ 死信队列实现延迟MQ消息,消息延迟,MQ延迟队列

本文介绍了通过RabbitMQ的死信队列实现消息延迟的原理,详细阐述了如何在Springboot中创建延迟消息队列,并讨论了在设置不同过期时间时可能出现的问题及解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过RabbitMQ 死信队列实现延迟MQ消息,消息延迟,MQ延迟队列


1、延迟消息原理

客户端向MQ服务器发送一条队列消息,该消息设置了TTL【该消息在超过TTL的时间内没有被消费,就会被视为是死信】,但是不给该队列提供消费者,在消息超时后,由死信交换机转发该消息到指定的消费者,以实现延迟队列。

简单点说,就是向一个没有消费者的队列发送一条有过期机制的消息,消息过期后死信交换机DLK把消息转发给一个没有生产者的队列,以实现消费。

2、如何在Springboot 下创建延迟消息队列

只需要正常的创建2个队列,然后设置三个属性即可创建延迟消息队列

    @Bean(DEAD_LETTER_PROD)
    Queue a() {
        Map<String,Object> args = Maps.newHashMap();
        // RabbitMqExchange.ExchangeCenter.DEAD_LETTER_EXCHANGE_CONSUME  只是一个交换机的名称,可以按需要定义
        args.put("x-dead-letter-exchange", RabbitMqExchange.ExchangeCenter.DEAD_LETTER_EXCHANGE_CONSUME);
        // 消息过期转发到那个队列去
        args.put("x-dead-letter-rout
### 使用 MQ 死信队列实现消息延迟消费的方法 #### 配置死信交换机和队列 为了实现消息延迟消费,首先需要创建一个普通的交换机和队列,并指定该队列的消息在超过设定的时间存活 (TTL) 后转发至特定的死信交换机。这可以通过声明带有 `x-dead-letter-exchange` 和 `x-dead-letter-routing-key` 参数的队列来完成[^1]。 ```java @Bean public Queue delayQueue() { Map<String, Object> args = new HashMap<>(); args.put("x-message-ttl", 5000); // 设置消息过期时间为5秒 args.put("x-dead-letter-exchange", "dlx.exchange"); // 指定死信交换机名称 args.put("x-dead-letter-routing-key", "dlx.routingKey"); // 指定死信路由键名 return new Queue("delay.queue", true, false, false, args); } ``` #### 定义死信处理逻辑 当原队列中的消息达到其 TTL 并成为死信之后,这些消息将会按照预先定义好的规则被重新发布到另一个由开发者自定义的死信队列中等待进一步处理。此时可以在应用程序里监听这个新的队列并执行相应的业务操作[^2]。 ```java @RabbitListener(queues = "dead.real.queue") public void listenDeadLetterQueue(Message message) throws Exception { System.out.println("Received dead letter message: " + new String(message.getBody())); // 处理接收到的死信... } ``` #### 发送带有时效性的消息 发送方可以向正常的工作队列投递携带有效期限属性的消息对象;一旦这条记录超过了所给定的最大生命周期,则自动进入下一流程阶段——即变为一条“死信”,进而触发后续动作[^3]。 ```java rabbitTemplate.convertAndSend( exchangeName, routingKeyName, message, msg -> { msg.getMessageProperties().setExpiration(String.valueOf(ttlInMillis)); return msg; } ); ``` 通过上述方式能够有效地利用 RabbitMQ 提供的功能特性构建起一套简单而可靠的延时任务调度系统[^4]。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

简简单单OnlineZuozuo

感谢哥哥姐姐的打赏

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值