热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

RabbitMQ高级过期时间TTL

概述过期时间TTL表示可以对消息设置预期的时间,在这个时间内都可以被消费者接收获取;过期后自动被删除;RabbitMQ可以对消息和队列设置TTL。目前有两种方法可以设置第一种方法是











概述

过期时间 TTL 表示可以对消息设置预期的时间,在这个时间内都可以被消费者接收获取;过期后自动被删除;RabbitMQ 可以对消息和队列 设置 TTL。目前有两种方法可以设置
第一种方法是通过队列属性的设置,队列中所有消息多有相同的过期时间
第二种方法是对消息单独设置,每条消息 TTL 可以不同
这两种方式的区别在于通过队列属性设置的消息是移到死信队列中,而单独消息设置 TTL 是消息自动消失。
如果上述两种方法同时使用,则消息的过期时间可以两者之间 TTL 较小的哪个数值为准。消息在队列的生存时间一旦超过设置的 TTL 值,就称为 dead message 被投递到死信队列,消费者将无法再收到该消息。

设置队列 TTL

配置类配置如下

@Configuration
public class TTLRabbitMqConfiguration {
@Bean
public DirectExchange ttlDirectExchange() {
return new DirectExchange("ttl_direct_order_exchange",true,false);
}
@Bean
public Queue directTtlQueue() {
// 设置过期时间
HashMap<String, Object> args = new HashMap<>();
args.put("x-message-ttl",5000); // 这里一定是一个int类型
return new Queue("ttl.direct.queue",true,false,false,args);
}
@Bean
public Binding ttlBinding() {
return BindingBuilder.bind(directTtlQueue()).to(ttlDirectExchange()).with("ttl");
}
}
public void makeOrderTtl(String userId,String productId,int num) {
// 1:根据id查询商品是否充足
// 2:保存订单
String orderId = UUID.randomUUID().toString();
System.out.println("订单生成成功:"+orderId);
// 3:通过 MQ 来完成消息的分发
// 交换机,路由 key/queue 队列名称,消息内容
String exchangeName = "ttl_direct_order_exchange";
String routingKey = "ttl";
rabbitTemplate.convertAndSend(exchangeName,routingKey,orderId);
}

测试代码

@Test
void testOrderTtl() {
orderService.makeOrderTtl("1","1",12);
}

RabbitMQ 高级 - 过期时间 TTL

五秒过后数据自动消失

RabbitMQ 高级 - 过期时间 TTL

RabbitMQ 高级 - 过期时间 TTL


消息设置过期时间

config 配置代码

@Configuration
public class TTLRabbitMqConfiguration {
@Bean
public DirectExchange ttlDirectExchange() {
return new DirectExchange("ttl_direct_order_exchange",true,false);
}
@Bean
public Queue directTtlQueue() {
// 设置过期时间
HashMap<String, Object> args = new HashMap<>();
args.put("x-message-ttl",5000); // 这里一定是一个int类型
return new Queue("ttl.direct.queue",true,false,false,args);
}
@Bean
public Queue directTtlMessageQueue() {
return new Queue("ttl.message.direct.queue",true);
}
@Bean
public Binding ttlBinding() {
return BindingBuilder.bind(directTtlMessageQueue()).to(ttlDirectExchange()).with("ttlMessage");
}
}

测试代码

public void makeOrderTtlMessage(String userId,String productId,int num) {
// 1:根据id查询商品是否充足
// 2:保存订单
String orderId = UUID.randomUUID().toString();
System.out.println("订单生成成功:"+orderId);
// 3:通过 MQ 来完成消息的分发
// 交换机,路由 key/queue 队列名称,消息内容
String exchangeName = "ttl_direct_order_exchange";
String routingKey = "ttlMessage";
// 给消息设置过期时间
MessagePostProcessor messagePostProcessor = new MessagePostProcessor() {
@Override
public Message postProcessMessage(Message message) throws AmqpException {
// 设置过期时间
message.getMessageProperties().setExpiration("5000");
message.getMessageProperties().setContentEncoding("UTF-8");
return message;
}
};
rabbitTemplate.convertAndSend(exchangeName,routingKey,orderId,messagePostProcessor);
}
@Test
void testOrderTtlMessage() {
orderService.makeOrderTtlMessage("1","1",12);
}

五秒之后消息自动过期消失

RabbitMQ 高级 - 过期时间 TTL

RabbitMQ 高级 - 过期时间 TTL


总结

如果既设置了消息ttl,又设置了队列 ttl,是以最短时间为准。队列 ttl 对比 消息 ttl 优势在于,之后会有死信队列队列,将这些过期的消息发送到死信队列。




rabbitmq


推荐阅读
  • 深入理解Kafka服务端请求队列中请求的处理
    本文深入分析了Kafka服务端请求队列中请求的处理过程,详细介绍了请求的封装和放入请求队列的过程,以及处理请求的线程池的创建和容量设置。通过场景分析、图示说明和源码分析,帮助读者更好地理解Kafka服务端的工作原理。 ... [详细]
  • 本文介绍了OpenStack的逻辑概念以及其构成简介,包括了软件开源项目、基础设施资源管理平台、三大核心组件等内容。同时还介绍了Horizon(UI模块)等相关信息。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
  • java线程池的实现原理源码分析
    这篇文章主要介绍“java线程池的实现原理源码分析”,在日常操作中,相信很多人在java线程池的实现原理源码分析问题上存在疑惑,小编查阅了各式资 ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • LeetCode笔记:剑指Offer 41. 数据流中的中位数(Java、堆、优先队列、知识点)
    本文介绍了LeetCode剑指Offer 41题的解题思路和代码实现,主要涉及了Java中的优先队列和堆排序的知识点。优先队列是Queue接口的实现,可以对其中的元素进行排序,采用小顶堆的方式进行排序。本文还介绍了Java中queue的offer、poll、add、remove、element、peek等方法的区别和用法。 ... [详细]
  • linux进阶50——无锁CAS
    1.概念比较并交换(compareandswap,CAS),是原⼦操作的⼀种,可⽤于在多线程编程中实现不被打断的数据交换操作࿰ ... [详细]
  • 广度优先遍历(BFS)算法的概述、代码实现和应用
    本文介绍了广度优先遍历(BFS)算法的概述、邻接矩阵和邻接表的代码实现,并讨论了BFS在求解最短路径或最短步数问题上的应用。以LeetCode中的934.最短的桥为例,详细阐述了BFS的具体思路和代码实现。最后,推荐了一些相关的BFS算法题目供大家练习。 ... [详细]
  • 本文介绍了如何通过维持两个堆来获取一个数据流中的中位数。通过使用最大堆和最小堆,分别保存数据流中较小的一半和较大的一半数值,可以保证两个堆的大小差距为1或0。如果数据流中的数量为奇数,则中位数为较大堆的最大值;如果数量为偶数,则中位数为较大堆的最大值和较小堆的最小值的平均值。可以使用优先队列来实现堆的功能。本文还提供了相应的Java代码实现。 ... [详细]
  • 第七课主要内容:多进程多线程FIFO,LIFO,优先队列线程局部变量进程与线程的选择线程池异步IO概念及twisted案例股票数据抓取 ... [详细]
  • C++ STL复习(13)容器适配器
    STL提供了3种容器适配器,分别为stack栈适配器、queue队列适配器以及priority_queue优先权队列适配器。不同场景下,由于不同的序列式 ... [详细]
  • 基于分布式锁的防止重复请求解决方案
    一、前言关于重复请求,指的是我们服务端接收到很短的时间内的多个相同内容的重复请求。而这样的重复请求如果是幂等的(每次请求的结果都相同,如查 ... [详细]
  • 浅析对象 VO、DTO、DO、PO 概念
    作者|CatQi链接|cnblogs.comqixuejiap4390086.html前言由于此订阅号换了个皮肤,导致用户接受文章不及时。读者可以打开订阅号「Web项 ... [详细]
  • RabbitMq之发布确认高级部分1.为什么会需要发布确认高级部分?在生产环境中由于一些不明原因,导致rabbitmq重启,在RabbitMQ重启期间生产者消息投递失败,导致消息丢 ... [详细]
  • RingBuffer,或者说CircularBuffer,是一个长度固定的缓冲区,当从一端插入元素超过指定的最大长度时,缓冲区另一端的元素 ... [详细]
author-avatar
核能裸麦_536
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有