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

发送端以某种规则将消息转成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等序列化形式。以此提高性能。

最新文章

  1. SQL 表连接查询出现重复列,由此理清LEFT JOIN、INNER JOIN的区别
  2. <li>高度自适应
  3. linux下PostgreSQL数据库的源码安装
  4. iisapp 命令 弹出 iisschlp.wsc [88,25] 属性值无效 progid
  5. jdbc中的Statement对象和Preparedstatement对象的区别,以及通过jdbc操作调用存储过程
  6. linux 启动oracle报cannot restore segment prot after reloc: Permission denied
  7. 美丽的CSS图形和HTML5
  8. [DeeplearningAI笔记]ML strategy_2_1误差分析
  9. 4-STM32物联网开发WIFI(ESP8266)+GPRS(Air202)系统方案安全篇(为域名申请SSl证书)
  10. No code signature found. 解决方式
  11. Luffy之课程详情页
  12. java 泛型详解-绝对是对泛型方法讲解最详细的,没有之一
  13. [转帖]ARM 相关内容
  14. 笔记 oracle 创建联合主键
  15. CSS控制边界、边框与外轮廓
  16. 升级vue-cli为 cli3 并创建项目
  17. Android GridView异步加载图片和加载大量图片时出现Out Of Memory问题
  18. IOS-每个程序员的编程之路上都应该看这11本书
  19. maven打包jar源码至私服
  20. [设计模式-行为型]模板方法模式(Template Method)

热门文章

  1. Codeforces Round #311 (Div. 2)
  2. C# - 委托的使用
  3. HBASE完全分布式模式的安装
  4. Python 链接MysqlDB
  5. zabbix 监控jvm
  6. MongoDB学习笔记(三) 在MVC模式下通过Jqgrid表格操作MongoDB数据
  7. 【Visual C++】Windows GDI贴图闪烁解决方法
  8. VC++实现位图显示透明效果--实现原理
  9. mysql 创建函数 error Code: 1227. Access denied;
  10. 多校第五场 归并排序+暴力矩阵乘+模拟+java大数&记忆化递归