rabbitMq 死信队列(三)消息 TTL 过期成为死信

本文介绍了如何在RabbitMQ中设置消息生存时间(TTL)以实现消息自动过期,并将其转为死信。通过消费者代码展示了如何配置死信交换机和队列,当消息过期后,它们会进入死信队列。实验结果显示,10秒后普通队列中的消息消失,而死信队列接收到10条消息,验证了死信处理机制的有效性。
摘要由CSDN通过智能技术生成

消息 TTL 过期(消息生存时间过期)

消息生存时间过期就是说给消息设置一个生存时间,假如是10s那么10秒后消息就过期了,这个消息就变成了死信。大部分代码都是引用的上一章的代码rabbitMq 死信队列(一)消息被拒绝成为死信代码可以在此处获取

消息消费者C1编写

public class CustomerOne {
    /**
     * 普通交换机
     */
    public static final String NORMAL_EXCHANGE="normal_exchange";
    /**
     * 死信交换机
     */
    public static final String DEAD_EXCHANGE="dead_exchange";
    /**
     * 普通队列
     */
    public static final String NORMAL_QUEUE="normal_queue";
    /**
     * 死信队列
     */
    public static final String DEAD_QUEUE="dead_queue";

    public static void main(String[] args) throws Exception{
        Channel channel = RabbitMqUtils.getChannel();
        // 声明普通交换机
        channel.exchangeDeclare(NORMAL_EXCHANGE, BuiltinExchangeType.DIRECT);
        // 声明死信交换机
        channel.exchangeDeclare(DEAD_EXCHANGE,BuiltinExchangeType.DIRECT);
        // 普通队列相关参数
        Map<String, Object> arguments=new HashMap<>(16);
        // 消息成为死信交换机
        arguments.put("x-dead-letter-exchange",DEAD_EXCHANGE);
        // 设置死信routingKey
        arguments.put("x-dead-letter-routing-key","lisi");
        // 设置队列消息存在时间
         arguments.put("x-message-ttl",10000);
        // 声明普通队列
        channel.queueDeclare(NORMAL_QUEUE,false,false,false,arguments);
        // 绑定普通交换机
        channel.queueBind(NORMAL_QUEUE,NORMAL_EXCHANGE,"zhangsan");
        // 声明死信队列
        channel.queueDeclare(DEAD_QUEUE,false,false,false,null);
        // 绑定死信交换机
        channel.queueBind(DEAD_QUEUE,DEAD_EXCHANGE,"lisi");
        System.out.println("消息的接收.......");
        DeliverCallback deliverCallback = (String consumerTag, Delivery message) -> {
            String msg = new String(message.getBody());
            if("".equals(msg)){
                System.out.println("此消息被拒绝了 "+msg);
                /**
                 * 拒绝消息
                 * 1.消息的id
                 * 2.是否放回队列
                 */
                channel.basicReject(message.getEnvelope().getDeliveryTag(),false);
            }else {
                System.out.println("消息消费: "+msg);
                channel.basicAck(message.getEnvelope().getDeliveryTag(),false);
            }
        };
        CancelCallback cancelCallback=(consumerTag)->{
            System.out.println("消息消费被中断");
        };
        channel.basicConsume(NORMAL_QUEUE,false,deliverCallback,cancelCallback);
    }
}

上边这是在消息的消费端设置的消息生存时间,也可以在消费端设置消息的生存时间效果是一样的,添加相关的代码如下

在这里插入图片描述

启动项目

启动消息消费者C1构建相关的队列和交换机,然后启动消息的生产者,发现普通队列中有10条消息

在这里插入图片描述

10秒之后消息都没有了

在这里插入图片描述

死信队列中有10条消息,说明消息都变为了死信消息进入了死信队列

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

麦片王子

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

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

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

打赏作者

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

抵扣说明:

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

余额充值