rabbitmq 的 TTL

队列的 TTL

我们可以通过 ttl() 设置超时时间,单位是 ms

代码演示:

java 复制代码
    @Bean("ttlQueue")
    public Queue ttlQueue() {
        return QueueBuilder.durable(MQConstants.TTL_QUEUE).ttl(20000).build();
    }

设置超时时间为 20s,这样在这条队列的所有的消息的过期时间都是 20s 【前提是你没有给消息单独设置过 TTL】

我们会发现队列多了一个属性 TTL,可以看到过期时间 为 20 000 ms

消息的 TTL

这里需要传入一个字符串,单位为毫秒

在发送消息那行代码将过期时间设置进去

java 复制代码
    @RequestMapping("/ttl")
    public String ttl() {
        rabbitTemplate.convertAndSend(MQConstants.TTL_EXCHANGE, MQConstants.TTL_ROUTING_KEY, "ttl",
                messagePostProcessor -> {
                    messagePostProcessor.getMessageProperties().setExpiration("10000");
                    return messagePostProcessor;
                });
        return "消息发送成功";
    }

两者之间的区别

设置队列TTL属性的方法,一旦消息过期,就会从队列中删除设置消息TTL的方法,即使消息过期,也不会马上从队列中删除,而是在即将投递到消费者之前进行判定的。这样子做可以提高性能

为什么这两种方法处理的方式不一样?
因为设置队列过期时间,队列中已过期的消息肯定在队列头部,RabbitMQ只要定期从队头开始扫描是否有过期的消息即可。
而设置消息TTL的方式,每条消息的过期时间不同,如果要删除所有过期消息需要扫描整个队列,所以不如等到此消息即将被消费时再判定是否过期,如果过期再进行删除即可。

总结

有两种方法可以设置消息的TTL.
一是设置队列的TTL,队列中所有消息都有相同的过期时间
二是对消息本身进行单独设置,每条消息的TTL可以不同
如果两种方法一起使用,则消息的TTL以两者之间较小的那个数值为准。

相关推荐
云和数据.ChenGuang2 小时前
OpenEuler系统下RabbitMQ安装与基础配置教程
服务器·分布式·rabbitmq·ruby·数据库运维工程师·运维教程
云和数据.ChenGuang7 小时前
Deepseek适配场景:OpenEuler系统下RabbitMQ安装与基础配置教程
分布式·rabbitmq·ruby
Wang's Blog12 小时前
RabbitMQ: 消息发送失败的重试机制设计与实现
分布式·rabbitmq
武子康14 小时前
Java-206 RabbitMQ 发布订阅(fanout)Java 实战:推/拉模式、ACK 与绑定排错全梳理
java·分布式·消息队列·rabbitmq·rocketmq·java-rabbitmq·mq
武子康15 小时前
Java-207 RabbitMQ Direct 交换器路由:RoutingKey 精确匹配、队列多绑定与日志分流实战
java·消息队列·rabbitmq·erlang·ruby·java-rabbitmq
sinat_363954231 天前
canal-deployer1.1.8 + mysql + rabbitmq消息队列
mysql·rabbitmq
武子康1 天前
Java-204 RabbitMQ Connection/Channel 工作流程:AMQP 发布消费、抓包帧结构与常见坑
java·分布式·消息队列·rabbitmq·ruby·java-activemq
武子康1 天前
Java-205 RabbitMQ 工作模式实战:Work Queue 负载均衡 + fanout 发布订阅(手动ACK/QoS/临时队列)
java·性能优化·消息队列·系统架构·rabbitmq·java-rabbitmq·mq
Wang's Blog2 天前
RabbitMQ: 解析Kubernetes原理与高可用集群部署实践
分布式·kubernetes·rabbitmq
robin59112 天前
rabbitmq-深入理解exchange/queue/routing-key等概念
分布式·rabbitmq