RabitMq过期时间TTL
第一种:给消息设置过期时间 启动一个插件 @Bean
public DirectExchange DirectExchange() {
return new DirectExchange("ttl_direct_exchange", true, false);
} //给消息设置过期时间
@Bean
public Queue ttlMessageQueue() {
return new Queue("ttl.message.direct.queue", true);
} @Bean
public Binding ttlMessageBind() {
return BindingBuilder.bind(ttlMessageQueue()).to(DirectExchange()).with("ttlMessage");
} public void ttlMessage() {
String orderId= UUID.randomUUID().toString();
String exchangeName3="ttl_direct_exchange";
MessagePostProcessor messagePostProcessor=new MessagePostProcessor() {
//设置消息的过期时间
@Override
public Message postProcessMessage(Message message) throws AmqpException {
message.getMessageProperties().setExpiration("5000");
message.getMessageProperties().setContentEncoding("UTF-8");
return message;
}
};
String ttl="ttlMessage";
rabbitTemplate.convertAndSend(exchangeName3,ttl,orderId);
}
第二种给队列设置过期时间:
@Bean
public Queue ttlQueue() {
Map<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 ttlBind() {
return BindingBuilder.bind(ttlQueue()).to(DirectExchange()).with("ttl");
} public void makeOrder() {
String orderId= UUID.randomUUID().toString();
System.out.println("订单ok");
//带有过期时间的ttl
String exchangeName3="ttl_direct_exchange";
String ttl="ttl";
rabbitTemplate.convertAndSend(exchangeName3,ttl,orderId);
}
如果:设置了两种过期时间,以时间短的为基准,因为无论是队列先过期,还是队列里面的消息先过期,另一个单独存在都没有意义
队列过期和消息过期的最大区别是,队列过期了里面的信息可以当作别处用,去处理,比如死信队列,
而消息过期就是单纯的过期,就是这条消息没有了
RabitMq过期时间TTL的更多相关文章
- 【RabbitMQ 实战指南】一 过期时间TTL
		RabbitMQ 可以对消息和队列设置过期时间(TTL) 1.设置消息的TTL 目前有两种方式可以设置消息的TTL 第一种方式是通过队列属性设置,队列中所有消息都有相同的过期时间 第二种方式是对消息本 ... 
- rabbitMq 学习笔记(二) 备份交换器,过期时间,死信队列,死信队列
		备份交换器 备份交换器,英文名称为 Altemate Exchange,简称庙,或者更直白地称之为"备胎交换器". 生产者在发送消息的时候如果不设置 mandatory 参数, 那 ... 
- redis string类型设置过期时间后 再进行set操作,会清除过期时间
		版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明.本文链接:https://blog.csdn.net/qq_41756437/article/d ... 
- redis基本操作和 过期时间设置以及持久化方案
		Redis是NOSQL阵营中的一种数据库,主要用于存储缓存 五大数据类型:字符串(String).散列(hash).列表(list).集合(set).有序集合(SortedSett .zset) St ... 
- redis入门指南(三)——  事务、过期时间、SORT命令、消息通知与管道
		写在前面 学习<redis入门指南>笔记,结合实践,只记录重要,明确,属于新知的相关内容. 事务 1.redis中的事务由一组命令的集合组成,要么都执行,要么都不执行,同时redis的事务 ... 
- RabbitMQ 设置消息的TTL(过期时间)
		我们在RabbitMQ中发布消息时,在代码中有两种方法设置某个队列的消息过期时间: 1.针对队列来说,可以使用x-message-ttl参数设置当前队列中所有消息的过期时间,即当前队列中所有的消息过期 ... 
- RabbitMQ(三)RabbitMQ消息过期时间(TTL)
		在RabbitMQ(二)AMQP协议mandatory和immediate标志位区别中我们提到,在RabbitMQ3.0以后的版本里,去掉了immediate参数支持,要实现类似的确认功能要使用TTL ... 
- redis中获取没有设置ttl过期时间的key
		需求:redis作为一个内存型的数据库,我们需要对过期key保持关注,从info keyspace中可以看出有多少key没有设置过期时间,那么到底是哪些呢? 说明:关于redis ttl 的返回值,请 ... 
- RabbitMQ之TTL(Time-To-Live 过期时间)
		本文转载自RabbitMQ之TTL(Time-To-Live 过期时间) 概述 RabbitMQ可以对消息和队列设置TTL. 目前有两种方法可以设置.第一种方法是通过队列属性设置,队列中所有消息都有相 ... 
随机推荐
- FPGA经典:Verilog传奇与基于FPGA的数字图像处理原理及应用
			一 简述 最近恶补基础知识,借了<<Verilog传奇>>,<基于FPGA的嵌入式图像处理系统设计>和<<基千FPGA的数字图像处理原理及应用>& ... 
- 微信小程序云开发-云函数-初始化云函数环境
			一.新建云函数文件夹 新建的云函数文件夹,命名为cloud,该文件夹一定要与pages文件夹同级.此时该文件夹的前面没有云朵的标识. 二.配置project.config.json文件 在proje ... 
- java开源项目学习
			http://jeecg-boot.mydoc.io/ 在线文档已切换至新地址: http://doc.jeecg.com Jeecg-Boot 是一款基于SpringBoot+代码生成器的快速开发平 ... 
- Deepin V20.1 解决安装Edge浏览器后更新系统报错的方法
			问题描述:有些人在deepin系统上安装完edge浏览器后采用sudo apt update命令更新系统,却报出了错误,更新失败.原因是更新deepin系统的时候,最好把其它的源禁用了,不然会有各样的 ... 
- Python基础之用PyQt5创建menu
			前一篇文章中,我们已经安装了PyQt5,并且已经测试过可用.那么接下来第一步开始学习如何创建菜单. 第一步:在想要运行py的地方右击External Tools-->designer,打开des ... 
- Java 异步编程的几种方式
			前言 异步编程是让程序并发运行的一种手段.它允许多个事情同时发生,当程序调用需要长时间运行的方法时,它不会阻塞当前的执行流程,程序可以继续运行,当方法执行完成时通知给主线程根据需要获取其执行结果或者失 ... 
- Hadoop 3.1.1 - 概述 - 总览
			Apache Hadoop 3.1.1 和之前发布的 3.0.X 版本线相比,Apache Hadoop 3.1.1 吸收了许多重要的改进. 总览 建议用户阅读完整的版本说明.本文提供了对主要变动的总 ... 
- Dubbo 实现一个Load Balance (用于灰度发布)
			Dubbo 可以实现的扩展很多, 官方文档在这: https://dubbo.apache.org/zh/docs/v2.7/dev/impls/ (太简单了....) 下面我们实现一个Load Ba ... 
- scrapy 错误:Missing scheme in request url: %s' % self._url
			先说报错原因:使用了和start_urls同名的参数 我通过scral crawl projename -a start_urls=http:example.com来传start_urls,然后想在项 ... 
- Java基础(一):I/O多路复用模型及Linux中的应用
			IO多路复用模型广泛的应用于各种高并发的中间件中,那么区别于其他模式他的优势是什么.其核心设计思想又是什么.其在Linux中是如何实现的? I/O模型 I/O模型主要有以下五种: 同步阻塞I/O:I/ ... 
