24 Netty解决TCP拆包粘包问题
3.1 TCP粘包拆包的问题
TCP是一个“流”协议,所谓流就是没有界限的遗传数据。TCP底层并不知道上层的业务数据的具体含义,他会根据TCP缓冲区的实际情况进行包的划分,也就是在业务上,我们一个完整的包可能会被TCP分成多个包进行发送,也可能把多个小包封装成一个大的数据包发送出去,这就是所谓的TCP粘包、拆包问题。
TCP粘包、拆包问题的产生原因:
1、应用程序write写入的字节小于大于套接口发送缓冲区的大小
2、及逆行MSS大小的TCP分段
3、以太网帧的payload大于MTU及逆行IP分片
解决TCP拆包粘包问题的方案:
1、消息定长,例如每个保温的大小固定为200个字节,如果不够空位补。
2、在包尾部添加特殊字符进行分割。
3、将消息分为消息头和消息体,在消息头中包含表示消息总长度的字段。
3.2 Netty解决拆包、粘包的问题
1、分隔符类DelimiterBasedFrameDecoder(自定义分隔符)
2、FixedLengthFrameDecoder(定长)