rabbitMQ 死信队列

本文介绍了死信队列,它用于存储过期和消费失败的消息,消费者从正常队列移除后消息会进入死信队列。消息变成死信一般有三种情况,即被拒绝且不重新入队、消息过期、队列达最大长度,还说明了创建死信队列的方法。

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

死信队列用于存储过期的消息和消费失败的消息。当消费者从正常队列移除后进入到死信队列。

1:消息变成死信 一 般是由于以下3种情况:


            1 :消息被拒绝 (Basic.Reject/Basic .Nack),井且设置 requeue 参数为 false;

// 创建队列消费者
final Consumer consumer = new DefaultConsumer(channel) {
    @Override
    public void handleDelivery(String consumerTag, Envelope envelope,
                               AMQP.BasicProperties properties, byte[] body) throws IOException {
        String message = new String(body, "UTF-8");
        System.out.println("消费者读取:" + message + "失败");
        // requeue为true 表示 拒绝消息后马上从队列中移除消息
        channel.basicNack(envelope.getDeliveryTag(),true,false);
    }
};

2 :消息过期

// 发送消息时设置过期时间为1秒 如果此时消费者没有开启一秒后进入死信队列
    AMQP.BasicProperties basicProperties = MessageProperties.PERSISTENT_TEXT_PLAIN;
        AMQP.BasicProperties props = new AMQP.BasicProperties
                .Builder()
                .deliveryMode(2)
                .expiration("1000")
                .build(); // AMQP.BasicProperties
        for (int i = 0; i < 1; i++) {
            channel.basicPublish(exchanageName, "com.baidu", props, message.getBytes());
            System.out.println("生产者发送:" + message + "'");
        }
        


          3:队列达到最大长度。

2:创建死信队列 添加("x-dead-letter-exchange", "dlx.exchange"); dlx.exchange为你自定义的值 此值是死信队列dlx.queue的exchange,死信队列可以任意个只要队列的exchange和x-dead-letter-exchange的值对应。

        // 普通队列
        String exchangeName = "exchange_topic01";
        String routingKey = "com.#";
        String queueName = "queue1";
        channel.exchangeDeclare(exchangeName, "topic", true, false, null);
        Map<String, Object> agruments = new HashMap<String, Object>();
        agruments.put("x-dead-letter-exchange", "dlx.exchange");
        //这个agruments属性设置到
        channel.queueDeclare(queueName, true, false, false, agruments);
        channel.queueBind(queueName, exchangeName, routingKey);

        
        //死信队列dlx.exchange 与 上面x-dead-letter-exchange的值对应
        String exchangeDxl = "dlx.exchange";
        String routingKeyDxl = "#";
        String queueNameDxl = "dlx.queue";
        channel.exchangeDeclare(exchangeDxl, "topic", true);
        channel.queueDeclare(queueNameDxl, true, false, false, null);
        channel.queueBind(queueNameDxl, exchangeDxl, routingKeyDxl);

 

 

 

### 配置和使用RabbitMQ死信队列 #### 创建死信交换机与队列 为了使消息能够被转发至死信队列,在创建常规队列时需指定特定参数来关联死信交换机及其路由键。这可以通过编程方式完成,例如在Java Spring Boot环境中: ```java @Bean(name = "deadExchange") public TopicExchange deadExchange() { return ExchangeBuilder.topicExchange("DEAD_EXCHANGE").durable(true).build(); } @Bean(name = "deadQueue") public Queue deadQueue() { Map<String, Object> args = new HashMap<>(); args.put("x-dead-letter-exchange", "DEAD_EXCHANGE"); args.put("x-dead-letter-routing-key", "DEAD_ROUTING_KEY"); return QueueBuilder.durable("DEAD_QUEUE").withArguments(args).build(); } ``` 上述代码片段展示了如何通过`@Bean`注解定义死信交换机以及带有额外参数的死信队列[^4]。 #### 绑定关系设置 接着需要建立正常的交换机、队列同死信机制之间的联系。对于每一个可能产生死信的消息队列而言,应该设定相应的绑定规则以便于当条件满足时可以将这些未成功消费的消息重定向给预设好的死信队列: ```java @Bean public Binding normalBinding(DirectExchange directExchange, Queue normalQueue) { // 正常情况下使用的binding... // 设置该队列产生的死信会被发送到哪个exchange/routing key Map<String, Object> arguments = new HashMap<>(); arguments.put("x-dead-letter-exchange", "DEAD_EXCHANGE"); arguments.put("x-dead-letter-routing-key", "DEAD_ROUTING_KEY"); return BindingBuilder.bind(normalQueue) .to(directExchange) .with("NORMAL_ROUTING_KEY") .arguments(arguments); } ``` 此部分逻辑同样适用于其他类型的交换模式(如topic,fanout等),只需调整具体的匹配模式即可[^1]。 #### 处理死信 一旦消息变为死信并到达对应的死信队列之后,则可以根据业务需求对其进行适当的操作,比如记录日志、尝试再次投递给原始队列或者其他形式的数据持久化操作[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值