粘包拆包问题出现的原理
粘包拆包问题是发生在网络比较底层的问题,在数据链路层,网络层以及传输层都有可能发生。
我们日常的网络应用开发大都是在传输层进行的
UDP有消息保护边界, 不会发生这个问题
出现粘包和拆包主要有以下几个原因
- 应用程序写入的数据大于套接字缓冲区大小,这将会发生拆包问题
- 应用程序写入的数据小于套接字缓冲区大小,网卡将应用多次写入的数据发送到网络上,这将会发生粘包问题
- 进行MSS(最大报文长度)大小的TCP分段,当TCP报文长度 - TCP头部长度 > MSS的时候,将发生拆包的问题
- 接收方法不及时读取套接字缓冲区的数据,这将发生粘包问题
解决粘包拆包的方法
- 使用自定义协议+编解码器
- 设置定长消息,服务端每次读取特定长度的内容作为一条完整消息
- 设置消息边界,服务端从网络流中按消息编辑分离出消息内容
Netty中常用的拆包器
行拆包器-LineBasedFreamDecoder
按行进行拆分,发送端每个数据之间要用换行符作为分隔符,接收端也会按照换行符将字节流拆分成业务消息
基于分隔符的拆包器-DeliiterBasedFrameDecoder
DeliiterBasedFrameDecoder允许指定一个分隔符,在接收消息的时候按照指定的分隔符进行拆包
基于定长的拆包器-FixedLengthFrameDeoder
这种情况只基于知道长度的情况下