TCP可靠传输怎么实现的

我们都知道 TCP 是可靠的,UDP 是不可靠的。但 TCP 到底凭什么可靠?它在底层到底做了哪些努力?

这篇文章带你一次性吃透 TCP 保证可靠传输的 6 大核心机制,原理 + 流程 + 专业描述全部到位。


引言:什么是 "可靠传输"?

可靠传输 = 数据不丢、不乱、不重、不坏。TCP 就是通过一整套严密机制,在不可靠的 IP 网络之上,实现了可靠的数据通信。

下面是 TCP 可靠性的6 大核心机制


1. 序列号与确认应答(ACK)

这是 TCP 可靠传输的基础

  • 序列号(seq) 发送的每个字节数据都会有一个唯一编号,按顺序递增。作用:保证按序到达去重

  • 确认应答(ACK) 接收方收到数据后,必须回复一个确认号:ack = 期望收到的下一个字节序号告诉发送方:之前的数据我已经收到了。

  • 例子:发送方发送 seq=100 的 100 字节数据接收方回复 ack=200表示:100~199 字节已收到,等待 200 开始。

作用:确认数据一定收到。


2. 超时重传

这是 TCP 应对丢包的机制。

  • 发送方发完数据后启动定时器
  • 如果超时没有收到 ACK
  • 就认为报文丢失,自动重传

超时时间会动态计算(RTT 平滑值),不会乱重传、不会频繁重传。

作用:丢了就重发,保证数据不丢失。


3. 流量控制(滑动窗口)

作用:防止接收方被 "撑爆"

  • 接收方在 ACK 里告诉发送方:Window Size(窗口大小)意思是:我还能收多少数据。

  • 发送方根据窗口大小控制发送速度

  • 接收方处理变慢 → 窗口变小

  • 接收方处理变快 → 窗口变大

作用:按需发送,不溢出、不丢失。


4. 拥塞控制

作用:防止网络拥堵崩溃

如果网络本身堵了,发送方还疯狂发数据,会导致大规模丢包。TCP 拥塞控制通过 4 个算法保证网络平稳:

  • 慢启动:刚开始慢,探测网络
  • 拥塞避免:线性提速,防止过载
  • 快重传:收到 3 个重复 ACK,立刻重传,不等超时
  • 快恢复:快速恢复速率,不 "断流"

作用:保护网络,让传输更稳定。


5. 连接管理:三次握手 + 四次挥手

TCP 是面向连接的协议,连接必须可靠建立、可靠关闭。

  • 三次握手 建立连接,同步双方序列号(ISN)确保双方发送、接收能力都正常

  • 四次挥手优雅断开,保证双方数据都传输完不丢数据、不截断

  • **TIME-WAIT(2MSL)**确保最后一个 ACK 到达对方防止旧报文干扰新连接

作用:连接本身必须可靠。


6. 校验和

作用:保证数据不损坏

  • 每个 TCP 报文都会计算校验和
  • 接收方收到后校验数据是否完整
  • 校验失败 → 直接丢弃 → 不回复 ACK → 触发发送方重传

作用:数据传输出错了就丢掉重传,保证正确性。

相关推荐
橘子132 小时前
ICMP协议
运维·服务器·网络
遥遥晚风点点2 小时前
JAVA http请求报错:unable to find valid certification path to requested target
java·网络·网络协议·http
智能工业品检测-奇妙智能2 小时前
openclaw使用硅基流动免费模型
服务器·人工智能·spring boot·电商·openclaw
chalmers_152 小时前
封禁暴力破解SSH的攻击IP
linux·服务器·ssh
taxunjishu2 小时前
EtherNet/IP 转 TCP/IP 网关方案助力工业自动化欧姆龙PLC产线设备互通
网络·物联网·自动化
成都极云科技2 小时前
2026年服务器托管收费标准解析 性价比对比及边缘节点选型全指南
运维·服务器·github
ShineWinsu2 小时前
对于Linux:基础指令的介绍—中
linux·运维·服务器·c++·面试·笔试·系统
haokan_Jia2 小时前
postgresql实现数据动态地图切片服务
java·服务器·前端
Z...........2 小时前
进 程
linux·运维·服务器