前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >如何修正Netty编解码的缺陷

如何修正Netty编解码的缺陷

作者头像
JavaEdge
发布2021-02-22 16:13:48
6550
发布2021-02-22 16:13:48
举报
文章被收录于专栏:JavaEdge

为什么会存在二次编解码

  • 把解决半包粘包问题的常用三种解码器叫一次解码器ByteToMessageDecoder

即从io.netty.buffer. ByteBuf ( 原始数据流) =》 io.netty.buffer .ByteBuf ( 用户数据)

但是在实际业务项目中,除可选的的压缩解压缩,还需一层解码,因为一次解码的结果是字节,需要和项目中所使用的对象做转化,方便使用,这层解码器可以称为“二次解码器”,相应的对应编码器是为了将Java对象转化成字节流方便存储或传输。 于是有了二次解码器:MessageToMessageDecoder io.netty.buffer.ByteBuf ( 用户数据) =》 Java Object

为何不一步到位?

合并1次解码(解决粘包、半包)和2次解码( 解决可操作问题) ? 可以,但不建议:

  • 没有分层, 不够清晰
  • 耦合性高,不容易置换方案 比如现在使用 protobuf,以后想用 json,就很麻烦咯。

常用的二次编解码方案

  • Java序列化
  • Marshaling
  • XML
  • JSON
  • MessagePack
  • Protobuf

编解码方案选型

  • 空间 编码后占用空间,需要比较不同的数据大小情况。
  • 时间 编解码速度,需要比较不同的数据大小情况。
  • 可读性
  • 多语言(Java 、C、Python 等)的支持

其中以谷歌的Protobuf最为知名。

Protobuf

  • 灵活的、高效的用于序列化数据的协议
  • 相比较XML和JSON格式,Protobuf更小、更快、更便捷
  • Protobuf是跨语言的,并且自带了一个编译器(protoc) ,只需要用它进行编译,可以自动生成Java、python、 C++等代码,不需要再写其他代码。
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/12/21 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 为什么会存在二次编解码
    • 为何不一步到位?
    • 常用的二次编解码方案
      • 编解码方案选型
        • Protobuf
    相关产品与服务
    文件存储
    文件存储(Cloud File Storage,CFS)为您提供安全可靠、可扩展的共享文件存储服务。文件存储可与腾讯云服务器、容器服务、批量计算等服务搭配使用,为多个计算节点提供容量和性能可弹性扩展的高性能共享存储。腾讯云文件存储的管理界面简单、易使用,可实现对现有应用的无缝集成;按实际用量付费,为您节约成本,简化 IT 运维工作。
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档