深入理解Netty编解码、粘包拆包、心跳机制( 四 )
接着编写发送端代码 , 根据解码器的设置 , 进行发送:
@Overridepublic void channelActive(ChannelHandlerContext ctx) throws Exception { for (int i = 1; i <= 5; i++) {String str = "msg No" + i;ByteBuf byteBuf = Unpooled.buffer(1024);byte[] bytes = str.getBytes(Charset.forName("utf-8"));//设置长度域的值 , 为有效数据的长度byteBuf.writeInt(bytes.length);//设置有效数据byteBuf.writeBytes(bytes);ctx.writeAndFlush(byteBuf);}}
然后启动服务端 , 客户端 , 我们可以看到控制台打印结果:
文章插图
可以看到 , 利用自定义长度帧解码器解决了粘包问题 。
使用Google Protobuf编解码器Netty官网上是明显写着支持Google Protobuf的 , 如下图所示:
文章插图
Google Protobuf是什么官网的原话: Protocol buffers are Google's language-neutral, platform-neutral, extensible mechanism for serializing structured data – think XML, but smaller, faster, and simpler. You define how you want your data to be structured once, then you can use special generated source code to easily write and read your structured data to and from a variety of data streams and using a variety of languages.
翻译一下:Protocol buffers是Google公司的与语言无关、平台无关、可扩展的序列化数据的机制 , 类似XML , 但是更小、更快、更简单 。 您只需定义一次数据的结构化方式 , 然后就可以使用特殊生成的源代码 , 轻松地将结构化数据写入和读取到各种数据流中 , 并支持多种语言 。
在rpc或tcp通信等很多场景都可以使用 。 通俗来讲 , 如果客户端和服务端使用的是不同的语言 , 那么在服务端定义一个数据结构 , 通过protobuf转化为字节流 , 再传送到客户端解码 , 就可以得到对应的数据结构 。 这就是protobuf神奇的地方 。 并且 , 它的通信效率极高 , “一条消息数据 , 用protobuf序列化后的大小是json的10分之一 , xml格式的20分之一 , 是二进制序列化的10分之一” 。
Google Protobuf 官网 :
为什么使用Google Protobuf在一些场景下 , 数据需要在不同的平台 , 不同的程序中进行传输和使用 , 例如某个消息是用C++程序产生的 , 而另一个程序是用java写的 , 当前者产生一个消息数据时 , 需要在不同的语言编写的不同的程序中进行操作 , 如何将消息发送并在各个程序中使用呢?这就需要设计一种消息格式 , 常用的就有json和xml , protobuf出现的则较晚 。
Google Protobuf优点
- protobuf 的主要优点是简单 , 快;
- protobuf将数据序列化为二进制之后 , 占用的空间相当小 , 基本仅保留了数据部分 , 而xml和json会附带消息结构在数据中;
- protobuf使用起来很方便 , 只需要反序列化就可以了 , 而不需要xml和json那样层层解析 。
安装最新版本的protoc
- 从github上下载 protobuf3
Mac系统选择第一个 , 如下图所示:
文章插图
- 下载成功后 , 切换到root用户
sudo -i
- 全新8核国产CPU深入探秘:马上能买到
- 数据|新基建时代,高大全的数据管理解决方案是怎样“炼”成的?
- 16G运存+256G内存,专业骁龙865旗舰,性价比深入人心
- 绿色骑行深入校园,共享单车长途长时需求量提升
- 不被理解的超时代发明,你知道几个?在线膜拜大神,西瓜视频真相
- 深入调查SolarWinds黑客事件 微软已查封一个核心服务器
- 《深入理解Java虚拟机》:Java内存区域
- 基于Netty高性能RPC框架Nifty协议、传输层、编解码
- 深入探讨 JavaScript 逻辑赋值运算符
- 彻底理解 IO 多路复用实现机制