一、前言
- TTL 全称 Time To Live(存活时间/过期时间)
- 当消息到达存活时间后,还没有被消费,会被自动清除
- RabbitMQ可以对消息设置过期时间,也可以对整个队列(Queue)设置过期时间
二、指定消息的过期时间
-
消息推送到队列后,如果指定时间内没有被消费,则会自动过期;
@SpringBootTest public class RabbitMQTest { @Autowired private RabbitTemplate rabbitTemplate; @Test public void test(){ MessageProperties messageProperties = new MessageProperties(); // 设置过期时间,单位:毫秒 messageProperties.setExpiration("10000"); byte[] msgBytes = "rabbitmq ttl message ...".getBytes(); Message message = new Message(msgBytes, messageProperties); //发送消息 rabbitTemplate.convertAndSend(RabbitMQConfig.ITEM_EXCHANGE,"info",message); System.out.println("发送消息成功"); } }
三、给队列中的所有消息设置过期时间
-
凡是推送到该队列中的所有消息,都会有一个多少秒后过期的属性;
@Configuration public class RabbitMQConfig { //交换机名称 public static final String ITEM_EXCHANGE = "item_exchange"; //队列名称 public static final String ITEM_QUEUE = "item_queue"; //声明交换机 @Bean("itemExchange") public Exchange itemExchange(){ return ExchangeBuilder.directExchange(ITEM_EXCHANGE).durable(true).build(); } //声明队列 @Bean("itemQueue") public Queue itemQueue(){ return QueueBuilder.durable(ITEM_QUEUE).ttl(3000).build(); } //绑定队列和交换机 @Bean public Binding itemQueueExchange(@Qualifier("itemQueue") Queue queue, @Qualifier("itemExchange") Exchange exchange){ return BindingBuilder.bind(queue).to(exchange).with("info").noargs(); } }
四、总结
- 设置队列过期时间使用参数:x-message-ttl,单位:ms(毫秒),会对整个队列消息统一过期;
- 设置消息过期时间使用参数:expiration。单位:ms(毫秒),当该消息在队列头部时(消费时),会单独判断这一消息是否过期;
- 如果两者都进行了设置,以时间短的为准。