熟悉tcp编程的可能都知道,无论是服务器端还是客户端,当我们读取或者发送数据的时候,都需要考虑TCP底层的粘包/拆包机制
TCP是一个“流”协议,所谓流就是没有界限的遗传数据。大家可以想象一下如果合理的水就好比数据,他们是连成一片的,没有分界线,TCP底层并不了解上层的业务数据具体的含义,它会根据TCP缓冲区的实际情况进行包的划分,也就是说,在业务上,我们一个完整的包可能会被TCP分成多个包进行发送,也可能把多个小包封装成一个大的数据包发送出去,这就是所谓的TCO粘包、拆包问题。
分析TCP粘包、拆包问题的产生原因:
1.应用程序write写入的字节大小大于套接口发送缓冲区的大小
2.进行MSS大小的TCP分段
3.以太网的payload大于MTU进行IP分片
TCP拆包、粘包解决方案
1.消息定长,例如每个报文的大小固定为200个字节,如果不够,空位补空格
2.在包尾部增加特殊字符进行分割。
3.将消息分为消息头和消息体,在消息头中包含表示消息总长度的字段,然后进行业务逻辑的处理