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