TCP拆包粘包问题解决-netty

熟悉tcp编程的可能都知道,无论是服务器端还是客户端,当我们读取或者发送数据的时候,都需要考虑TCP底层的粘包/拆包机制

TCP是一个“流”协议,所谓流就是没有界限的遗传数据。大家可以想象一下如果合理的水就好比数据,他们是连成一片的,没有分界线,TCP底层并不了解上层的业务数据具体的含义,它会根据TCP缓冲区的实际情况进行包的划分,也就是说,在业务上,我们一个完整的包可能会被TCP分成多个包进行发送,也可能把多个小包封装成一个大的数据包发送出去,这就是所谓的TCO粘包、拆包问题。

分析TCP粘包、拆包问题的产生原因:

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

2.进行MSS大小的TCP分段

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

TCP拆包、粘包解决方案

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

2.在包尾部增加特殊字符进行分割。

3.将消息分为消息头和消息体,在消息头中包含表示消息总长度的字段,然后进行业务逻辑的处理

你可能感兴趣的:(TCP拆包粘包问题解决-netty)