「RabbitMQ」使用死信队列处理超时和拒收消息的方案

文章介绍了如何在RabbitMQ中通过Java配置实现死信队列,包括设置x-dead-letter-exchange和x-dead-letter-routing-key参数,以及一个示例展示了消息在20秒未被消费后如何进入死信队列并被处理。

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

目录

介绍

使用 「Bean」配置死信队列

模拟生产者发送消息①


介绍

        Dead Letter Exchange(DLX)和 Dead Letter Queue(DLQ)通常用于处理未被消费的消息或处理失败的消息。当某个消息不能被成功路由到队列中时,我们可以将该消息发送到 DLX 中,然后再将其路由到 DLQ 中进行处理。

使用 「Bean 」 配置死信队列

  x-dead-letter-exchangex-dead-letter-routing-key 是 RabbitMQ 中常用的死信队列配置参数,可以将被拒绝或过期的消息重新发送到指定的队列和路由键中,以便进行处理。

下面是一个基于 Java 的 RabbitMQ 的例子,演示如何通过设置 x-dead-letter-exchangex-dead-letter-routing-key 参数来实现死信队列。

@Configuration
public class SimpleQueueConfig {
    Logger logger = LoggerFactory.getLogger(SimpleQueueConfig.class);

    @Bean(name = "simpleQueue")
    public Queue queue() {
        Map<String, Object> arguments = new HashMap<>(4);
        // 20秒内未被消费,则进入死信队列
        arguments.put("x-message-ttl", 20000);
        arguments.put("x-max-length", 1000);
        arguments.put("x-dead-letter-exchange", "dead.exchange");
        arguments.put("x-dead-letter-routing-key", "dead.message");
        return new Queue("simple_queue", true, false, true, arguments);
    }

    @Bean(name = "deadQueue")
    public Queue deadQueue() {
        return new Queue("dead.queue", true, false, true);
    }

    @Bean(name = "deadExchange")
    public Exchange exchange() {
        return new DirectExchange("dead.exchange", true, true);
    }

    @Bean(name = "deadBinding")
    public Binding binding() {
        return BindingBuilder.bind(deadQueue()).to(exchange()).with("dead.message").noargs();
    }

    @RabbitListener(queues = "dead.queue")
    public void readDeadMessage(String msg) {
        logger.info("接收到的死信消息为:{}", msg);
    }

//    @RabbitListener(queues = "simple_queue")
//    public void readMessage(String msg) {
//        logger.info("one接收到的消息为:{}", msg);
//    }
//
//    @RabbitListener(queues = "simple_queue")
//    public void readMessageTwo(String msg) {
//        logger.info("two接收到的消息为:{}", msg);
//    }
}

下面是 new Queue() 方法的各个参数的详解:

  1. name要创建的队列的名称。该参数为必选参数,不能为空或 null 值。

  2. durable是否将队列设置为持久化。持久化队列会将队列信息存储到磁盘上,即使 RabbitMQ 服务器停止运行或重启后也能够自动恢复队列。默认值为 false,表示不持久化。

  3. exclusive是否将队列设置成排他性质的队列。排他队列只能被首次声明它的连接使用,并在连接关闭时自动删除。默认值为 false,表示不是排他队列。

  4. autoDelete是否将队列设置为自动删除。即在最后一个消费者断开连接后,自动删除该队列。默认值为 false,表示不自动删除。

  5. arguments用于设置其他参数的可选参数,可以传入 null 或 Map<String, Object> 类型的参数列表。常见的参数有:

    • x-message-ttl:队列中消息的过期时间。单位为毫秒(ms)。例如,设置 x-message-ttl 为 10000 表示队列中的消息十秒钟后过期。

    • x-max-length:队列允许存放最大消息数。例如,设置 x-max-length 为 100 表示队列中最多能存放 100 条消息。

    • x-max-length-bytes:队列允许存放的最大字节数。例如,设置 x-max-length-bytes 为 1024 表示队列中最多能存放 1KB 的消息数据。

    • x-dead-letter-exchangex-dead-letter-routing-key:用于设置死信队列,即当队列中的消息被拒绝或超时时将消息发送到指定的队列和路由键。

        发送消息到simple_queue队列中,但是不去消费,让该队列的消息自动过期(此处设置的过期时间为20秒),进入死信队列中

 模拟生产者发送消息①

@SpringBootTest(classes = MqApplication.class)
@RunWith(SpringRunner.class)
public class ProducerSimpleTest {
    @Resource
    RabbitTemplate rabbitTemplate;

    @Test
    public void sendDelayMessageByDirect() {
        for (int i = 0; i < 10; i++) {
            rabbitTemplate.convertAndSend("simple_queue", "简单队列!!!!!");
        }
    }
}

         发送10条消息到simple_queue队列中,但是没有消费者去消费,消息设置的ttl时间为20秒,20秒都没有消费者去消费,那么则10条消息则进入死信队列中被死信消费者消费调

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

技术路上的探险家

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值