RabbitMq消息序列化简述

涉及网络传输的应用,序列化不可避免。发送端以某种规则将消息转成byte数组进行发送。

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


序列化的选择可以是jdk序列化,hessian,jackson,protobuf等。

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

hessia,protobuf等都是基于压缩重复字段的思想,减少传输数据量以提高性能。

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


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

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

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

只有调用了convertAndSend方法才会使用相应的MessageConvert进行消息的序列化与反序列化。


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

对于如果是String,则将String转成字节数组。

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


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

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值