Springboot|Springboot 2.x RabbitTemplate默认消息持久化的原因解析
目录
- 前言
- springboot测试
- 测试现象
- 源码分析
- 联想
前言 之前在Java直接测试mq消息持久化时,采取如下的配置实现消息的持久化:
//消息持久化测试Builder builder = new Builder(); builder.deliveryMode(2); BasicProperties properties = builder.build(); channel.basicPublish("", queue_name, properties, string.getBytes());
其中针对
BasicProperties
中的源码信息为:public static class BasicProperties extendscom.rabbitmq.client.impl.AMQBasicProperties {private String contentType; //消息类型如:text/plainprivate String contentEncoding; //编码private Map headers; private Integer deliveryMode; //1:nonpersistent 不持久 2:persistent 持久private Integer priority; //优先级private String correlationId; private String replyTo; //反馈队列private String expiration; //expiration到期时间private String messageId; private Date timestamp; private String type; private String userId; private String appId; private String clusterId; ...
参照博客:消息应答(autoAck)、队列持久化(durable)以及消息持久化
springboot测试 上面的配置是Java直接测试时,所需要编写的代码逻辑,如果采取springboot配置,则会出现
默认消息持久化
的现象。至于测试案例,可以参考下列博客:
Springboot整合rabbitmq之手动消息确认(ACK)
测试现象
首先将
消息消费者
代码进行注释
。执行接口,创建消息存入队列中。文章图片
文章图片
文章图片
源码分析
要想知道
为什么消息会自动持久化
,则需要关注rabbitTemplate.convertAndSend(exchange,routingKey,msg)
这个方法。从源码执行逻辑可以看出:
文章图片
rabbitTemplate
提供的消息加载至队列中,采取的数据类型为Object
,但在其源码逻辑中,又将Object
消息类型,进行了this.convertMessageIfNecessary(object)
处理,将object
对象类型转化为Message
对象类型。文章图片
从此处可以看出,
rabbitTemplate
为了让开发者处理数据更简单,将消息持久化
等操作默认进行了配置
。现在,一起来看
convertMessageIfNecessary(object)
做了什么?文章图片
判断当前的数据类型,
是否是Message类型
。如果是转换过程如下所示:Message
类型,则直接将其强转Message
。
如果不是,则执行了新的方法,将其转换了一次。
文章图片
文章图片
后面的就不深入了。那
持久化的默认配置在哪进行的?
回到最初的
convertAndSend
执行方法。文章图片
文章图片
文章图片
该参数由类创建加载时生成,其数据如下所示:
文章图片
文章图片
联想 也就是说,在
convertMessageIfNecessary
时,会判断传递的参数类型是否为Message
类型,如果不是则需要再包装一次。如果【Springboot|Springboot 2.x RabbitTemplate默认消息持久化的原因解析】到此这篇关于Springboot 2.x RabbitTemplate默认消息持久化的原因解析的文章就介绍到这了,更多相关Springboot 2.x RabbitTemplate默认消息持久化内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!不想设定消息持久化
,传递的数据类型为Message
类型即可!
推荐阅读
- SpringBoot|SpringBoot 如何使用sharding jdbc进行分库分表
- springboot2.x引入feign踩的坑及解决
- springboot|SpringBoot解决跨域问题
- springboot|springboot整合Mybatis-Plus
- java项目部署|Jenkins+Docker+Maven部署springboot项目
- springboot+jenkins+docker自动化部署
- 使用Jenkins+docker 部署springboot项目
- 开发工具|SpringBoot + maven + Jenkins + docker 实现docker集群一键自动化部署
- spring|Docker+jenkins+gitee+springboot实现自动化部署流程(详细教程)(附下载工具地址)(1)
- spring|Docker+jenkins+gitee+springboot实现自动化部署流程(详细教程)(附下载工具地址)(2)