一、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都已经失效了。
二、延迟队列
思路:给对列设置过期时间,将消息加入对列,过期时间之后消息自动进入死信队列,监听死信队列,进行消费操作可以实现延迟队列