zoukankan      html  css  js  c++  java
  • 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等序列化形式。以此提高性能。

  • 相关阅读:
    6th week blog3
    6th week blog2(颜色)
    6th week blog1(CSS单位)
    布局—一侧固定宽度,一侧自适应
    布局—两侧固定,中间自适应
    九宫格
    选项卡
    缓冲运动框架
    封装一些常用的js工具函数-不定时更新(希望大家积极留言,反馈bug^_^)
    在一定[min,max]区间,生成n个不重复的随机数的封装函数
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/5068780.html
Copyright © 2011-2022 走看看