(计算机网络)TCP 粘包与拆包

什么是粘包和拆包?

  • 粘包:指多条应用层消息在接收方一次性读到,数据"粘"在一起,无法区分消息边界。

    • 例子:客户端连续发送 [Hello][World],接收方一次 recv() 得到 [HelloWorld]
  • 拆包 :指一条应用层消息被 TCP 拆成多段传输,接收方需要多次 recv() 才能拼凑完整。

    • 例子:客户端发送 [HelloWorld],接收方第一次 recv() 得到 [Hello],第二次得到 [World]

一、为什么会出现粘包和拆包?

TCP 是面向字节流的协议,它只保证数据有序、不丢、不重复,但不会保留应用层消息的边界。

因此:

  • 应用层发送的多条消息,可能被 TCP 合并在一起(粘包)。

  • 一条消息可能被拆成多个数据包传输(拆包)。


二、粘包与拆包的场景

1. 粘包现象

客户端连续发送两条消息:

复制代码
[Hello]
[World]

服务端可能一次 recv() 收到:

复制代码
[HelloWorld]

👉 多条消息粘在一起。

2. 拆包现象

客户端发送一条很大的消息:

复制代码
[HelloWorldHelloWorld... 很长的数据]

服务端可能第一次收到:

复制代码
[HelloW]

第二次收到:

复制代码
[orldHello...]

👉 一条消息被拆开。


三、产生原因

  1. TCP 无消息边界:只是一条连续的字节流。

  2. Nagle 算法:小包会合并传输。

  3. 接收端读取不及时:缓冲区积累数据,导致粘在一起。

  4. 消息过大:超过 MTU 或 TCP 缓冲区,只能拆分。


四、解决方案

1. 定长消息

  • 每条消息固定大小,例如 1024 字节,不够补齐。

  • 缺点:浪费空间。

2. 分隔符

  • 在消息末尾加特殊字符(如 \n\r\n)。

  • 类似 HTTP 协议用 \r\n\r\n 分隔头和体。

相关推荐
FreeBuf_3 小时前
Zloader木马再次升级:通过DNS隧道和WebSocket C2实现更隐蔽的攻击
websocket·网络协议·php
chuxinweihui4 小时前
Socket编程UDP
linux·网络·网络协议·udp·通信
北京耐用通信4 小时前
神秘魔法?耐达讯自动化Modbus TCP 转 Profibus 如何为光伏逆变器编织通信“天网”
网络·人工智能·网络协议·网络安全·自动化·信息与通信
游戏开发爱好者85 小时前
TCP 抓包分析:tcp抓包工具、 iOS/HTTPS 流量解析全流程
网络协议·tcp/ip·ios·小程序·https·uni-app·iphone
kimi7047 小时前
HTTP的持续与非持续连接,HTTP报文格式
网络·网络协议·http
半桔8 小时前
【网络编程】TCP 粘包处理:手动序列化反序列化与报头封装的完整方案
linux·网络·c++·网络协议·tcp/ip
太阳伞下的阿呆9 小时前
Http与WebSocket
websocket·网络协议·http
2503_9248068517 小时前
动态IP使用中 报错407 怎么办???
服务器·tcp/ip·php
火星MARK17 小时前
如何配置 Ingress 的 SSL/TLS 证书?
网络·网络协议·ssl