RabbitMQ过期时间和延迟队列

一、RabbitMQ过期时间TTL

在设置时间范围内,消息都可被消费者接收消费,被消费后从队列中自动删除,设置过期时间方式:

1、设置队列属性,队列所有消息都有相同过期时间

<!--定义过期队列及其属性,不存在则自动创建-->
<rabbit:queue id="my_ttl_queue" name="my_ttl_queue" auto-declare="true">
<rabbit:queue-arguments>
<!--投递到该队列的消息如果没有消费都将在6秒之后被删除-->
<entry key="x-message-ttl" value-type="long" value="6000"/>
</rabbit:queue-arguments>
</rabbit:queue>

Spring Boot:在rabbitMq的配置文件中声明队列的时候设置

@Bean
    public Queue revisitWxNotifyQueue() {
        Map<String, Object> args = new HashMap<>();
        args.put("x-message-ttl", 3000); //消息过期时间
        return new Queue(NOTIFY_REVISIT_WX_QUEUE, true, false, false, args);
    }

2、对消息进行设置,每条消息的TTL可以不同

MessageProperties messageProperties = new MessageProperties();
//设置消息的过期时间,5秒,字符串类型
messageProperties.setExpiration("5000");

如果两种设置方式同时存在,则根据TTL最小时间生效。

注意:延迟队列中存放的数据最好设置TTL相同,如果ABC三条消息先后进入队列,存活时间是3h,2h,1h这样三小时A失效的时间BC都已经失效了。

二、延迟队列

思路:给对列设置过期时间,将消息加入对列,过期时间之后消息自动进入死信队列,监听死信队列,进行消费操作可以实现延迟队列

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值