TCP粘包、拆包 - 个人总结

TCP编程会产生粘包、拆包问题,现就此问题尽心详细分析,并提出解决方案。

1、什么是TCP粘包、拆包

TCP粘包、拆包 - 个人总结

2、产生粘包、拆包的原因:

1. 应用程序写入的数据大于套接字缓冲区大小,这将会发生拆包。
2. 应用程序写入数据小于套接字缓冲区大小,网卡将应用多次写入的数据发送到网络上,这将会发生粘包。
3. 进行MSS(最大报文长度)大小的TCP分段,当TCP报文长度-TCP头部长度>MSS的时候将发生拆包。
4. 接收方法不及时读取套接字缓冲区数据,这将发生粘包

3、解决方法:

TCP粘包、拆包 - 个人总结

4、其他解决方法:使用Netty提供的多种解码器

为了解决TCP粘包、拆包导致的半包读写问题,Netty默认提供了多种解码器用于处理半包。只要能熟练掌握这些类库的使用,TCP的粘包问题从此会变得非常容易,这也是其他NIO框架和JDK原生的NIO API所无法匹敌的。

4.1、使用LineBasedFrameDecoder + StringDecoder解决:

LineBasedFrameDecoder、StringDecoder原理解析:

TCP粘包、拆包 - 个人总结

4.2、使用 DelimiterBasedFrameDecoder、FixedLengthFrameDecoder

上面也提到了,TCP以流的方式进行数据传输,上层的应用协议为了对消息进行区分,往往采用如下4种方式:

TCP粘包、拆包 - 个人总结

TCP粘包、拆包 - 个人总结

除了上述介绍的两种,还可以使用 DelimiterBasedFrameDecoder、FixedLengthFrameDecoder:

DelimiterBasedFrameDecoder可以自动完成以分隔符做结束标志的消息的解码,

FixedLengthFrameDecoder可以自动完成对定长消息的解码,

TCP粘包、拆包 - 个人总结