TCP拆包粘包问题解决-netty

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

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

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

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

2.进行MSS大小的TCP分段

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

TCP拆包、粘包解决方案

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

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

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

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容