粘包拆包

说明

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

原因

  1. 应用程序write写入的字节大小大于套接口发送缓冲区大小;

  2. 进行MSS大小的TCP分段;

  3. 以太网帧的payload大于MTU进行IP分片。

解决策略

由于底层的TCP无法理解上层的业务数据,所以在底层是无法保证数据包不被拆分和重组的,这个问题只能通过上层的应用协议栈设计来解决。

解决策略:

  1. 消息定长,例如每个报文的大小为固定长度200字节,如果不够,空位补空格;

  2. 在包尾增加回车换行符进行分割,例如FTP协议;

  3. 将消息分为消息头和消息体,消息头中包含表示消息总长度的字段。

通过netty解决粘包拆包:

  1. LineBaseFrameDecoder:以换行符为结束标志的解码器;

  2. StringDecoder:将接收到的对象转换成字符串。

Last updated