RabbitMq消息序列化简述

转自   http://www.cnblogs.com/zfyouxi/p/5068780.html

涉及网络传输的应用。序列化不可避免。

发送端以某种规则将消息转成byte数组进行发送。

接收端则以约定的规则进行byte[]数组的解析。

 

序列化的选择能够是jdk序列化,hessian,jackson,protobuf等。

当中jdk序列化的缺点是性能及要求发送方与接收方都是java应用。

hessia。protobuf等都是基于压缩反复字段的思想。降低数据传输量以提高性能。

jackson是以json表示来数据传输。性能优于jdk序列化。

 

RabbitMq的序列化是指Message的body属性,即我们真正须要传输的内容。

RabbitMq抽象出一个MessageConverter接口处理消息的序列化,事实上现有SimpleMessageConverter,Jackson2JsonMessageConverter等。

当中默认的序列化类为SimpleMessageConverter。

仅仅有调用了convertAndSend方法才会使用对应的MessageConverter进行消息的序列化与反序列化。

 

SimpleMessageConverter对于要发送的消息体body为字节数组时。不进行处理。

对于假设是String。则将String转成字节数组。

对于假设是Java对象,则使用jdk序列化将消息转成字节数组。转出来的结果较大,含class类名。类对应方法等信息。因此性能较差。

 

当使用RabbitMq作为中间件时,数据量比較大,此时就要考虑使用类似Jackson2JsonMessageConverter。hessian等序列化形式。以此提高性能。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用RabbitMQ时,序列是一个重要的概念。序列是将对象转为可以在网络传输或存储中使用的字节序列的过程。使用序列可以方便地将对象在不同系统之间进行传递和交互。 在RabbitMQ中,可以使用不同的序列方式来处理消息序列。一种常用的方式是使用Jackson2JsonMessageConverter。这是一个基于Jackson库的消息转换器,可以将对象序列为JSON格式的字符串进行传输。通过配置RabbitTemplate的bean,将消息转译器设置为Jackson2JsonMessageConverter,可以实现将对象序列为JSON串。例如,在任意配置类下提供以下代码: @Bean public RabbitTemplate jacksonRabbitTemplate(ConnectionFactory connectionFactory) { RabbitTemplate rabbitTemplate = new RabbitTemplate(connectionFactory); rabbitTemplate.setMessageConverter(new Jackson2JsonMessageConverter()); return rabbitTemplate; } 除了Jackson2JsonMessageConverter,RabbitMQ还提供了其他的消息转换器实现,例如SimpleMessageConverter。这些不同的消息转换器实现了RabbitMQ的MessageConverter接口,可以根据需求选择合适的转换器。 通过选择适当的序列方式,可以提高RabbitMQ处理大数据量时的性能。使用序列可以将对象转为可传输的字节序列,并且在接收端可以将字节序列序列为对象,实现消息的传递和消费。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [RabbitMq消息序列简述](https://blog.csdn.net/zhaozhenzuo/article/details/46623213)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [工作随笔——rabbitmq消息序列与反序列(springboot)](https://blog.csdn.net/qq_43585377/article/details/109203762)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值