1. 粘包
是什么?
粘包半包是发生在TCP协议阶段的一种现象。粘包,就是在接受数据时,多个发送过来的TCP包“粘”在了一起。也就是一次性读到了发送的多个通信包 ,粘在一起,如果不能正确的将这些包分隔开,我们就没办法处理请求数据。
怎么办?
那么解决这个问题的思路就是,按照我们规定好的格式来,如果从TCP底层读到了多个应用层数据包,则将其拆成一个一个的独立的应用层数据包,返回上层应用,这个过程通常称为拆包。
2. 半包
是什么?
同理,半包就是一次发送过来的TCP包被“拆”开了。也就是一次读到的包不完整,
怎么办?
解决这个问题的思路就是,接收端应用层不断从底层的TCP 缓冲区中读取数据。每次读取完,判断一下是否为一个完整的应用层数据包。如果是,上层应用层数据包读取完成。如果不是,那就保留该数据在应用层缓冲区,然后继续从 TCP 缓冲区中读取,直到得到一个完整的应用层数据包为止。
3. Netty 中的拆包器
-
固定长度的拆包器 FixedLengthFrameDecoder
每个应用层数据包的都拆分成都是固定长度的大小,比如 1024字节。 -
行拆包器 LineBasedFrameDecoder
每个应用层数据包,都以换行符作为分隔符,进行分割拆分。 -
分隔符拆包器 DelimiterBasedFrameDecoder
每个应用层数据包,都通过自定义的分隔符,进行分割拆分。 -
基于数据包长度的拆包器 LengthFieldBasedFrameDecoder
将应用层数据包的长度,作为接收端应用层数据包的拆分依据。要求应用层协议中包含数据包的长度。
4. 读半包解码器
- LengthFieldBasedFrameDecoder
netty提供的通用半包解码器 - ProtobufVarint3FrameDecoder
netty提供的针对Protobuf的半包解码器 - 继承ByteToMessageDecoder类,自己处理半包消息