TCP通信在高并发的环境下,由于TCP是流式,数据包没有边界,导致了数据错乱的问题。
TCP是流式的,接收大的数据包时,该数据包可能被拆分成多份,多次发送,底层可能会合并一次性发送。于是,遇到了两个问题:
分包:收到的多个数据包,需要拆分。
合包:收到数据包只是一部分,需要缓存数据,合并成原包。
所以,TCP通信时需要制定通信协议。例如,HTTP、HTTPS、FTP、SMTP、POP3、IMAP、SSH、Redis、Memcache、MySQL等。
采用EOF协议分包:每个数据包的结尾加上特殊字符表示包结束,如 Memcache、FTP、SMTP 都使用 rn 作为结束符。发送数据时,则需要在末尾加上rn即可。但也这样意味着数据包中间不能有同样的EOF字符。



