粘包拆包
说明

TCP是一个“流“协议,所谓流,就是没有界限的一串数据。TCP底层并不了解上层业务数据的具体含义,它会根据TCP缓冲区的实际情况进行包的划分,所以在业务上认为,一个完整的包可能会被TCP拆分成多个包进行发送,也有可能把多个小的包封装成一个大的数据包发送,这就是所谓的TCP粘包和拆包问题。
原因

应用程序write写入的字节大小大于套接口发送缓冲区大小;
进行MSS大小的TCP分段;
以太网帧的payload大于MTU进行IP分片。
解决策略
由于底层的TCP无法理解上层的业务数据,所以在底层是无法保证数据包不被拆分和重组的,这个问题只能通过上层的应用协议栈设计来解决。
解决策略:
消息定长,例如每个报文的大小为固定长度200字节,如果不够,空位补空格;
在包尾增加回车换行符进行分割,例如FTP协议;
将消息分为消息头和消息体,消息头中包含表示消息总长度的字段。
通过netty解决粘包拆包:
LineBaseFrameDecoder:以换行符为结束标志的解码器;
StringDecoder:将接收到的对象转换成字符串。
Last updated