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

发送端以某种规则将消息转成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. socket.io,io=Manager(source, opts)
  2. 手机APP创建桌面快捷方式
  3. UWP 图片剪切旋转工具
  4. Spring事务解析4-切面织入
  5. [UML]UML系列——状态机图statechart diagram
  6. UVALive 7269 Snake Carpet (构造)
  7. 用re-sign.jar重签名apk后安装失败的解决办法
  8. python学习随笔
  9. C#面向对象编程基础-喜课堂笔记
  10. DEV TdxLayoutGroup设置tab
  11. JS--我发现,原来你是这样的JS:面向对象编程OOP[2]--(创建你的那个对象吧)
  12. jsp篇 之 Jsp中的内置对象和范围对象
  13. HTTP协议11-cookie和seesion
  14. zabbix添加对centos系统内存使用率百分比的监控
  15. android 中的Http请求类HttpUrlConnection和HttpClient类
  16. 基于mave的dubbo分别架构
  17. npm错误:Error: listen EADDRNOTAVAIL
  18. 在ASP.NET MVC中使用Knockout实践03,巧用data参数
  19. jq的attr()与prop()之间区别
  20. [ZHOJ1954]lyd的旅行

热门文章

  1. jvm常用参数设置 good
  2. android使用xfire webservice框架远程对sqlserver操作(包括增删改查)的实例!!已在真机上试验通过
  3. C 函数 strstr 的高效实现
  4. 理解 Thread.Sleep 函数
  5. Android学习-----如何使用sqlite对于后台数据交换,sqlite使用例程入门
  6. PropertyPlaceholderConfigurer类的使用注意
  7. Struts2他们拦截器实例定义—登陆权限验证
  8. operation is executing and cannot be enqueued
  9. 用gradle管理android项目出现的问题以及解决方法
  10. poj 1094