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 → 触发发送方重传

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

相关推荐
果丁智能7 小时前
智能锁赋能网约房民宿数字化管控:身份核验+远程授权,筑牢安全防线、降本增效
网络·数据库·人工智能·安全·智能家居
wp123_17 小时前
射频前端无源器件观察:Coilcraft WBC1-1TLC vs TONEVEE WBT1-1CT 国产与进口巴伦变压器的技术博弈
网络
映翰通朱工9 小时前
工业4G网关无公网IP远程运维实战(内网终端异地访问方案)
运维·服务器·网络·安全·智能路由器
天南散修9 小时前
MT7916 BA流程
网络·驱动开发·wifi·802.11
洪晓露9 小时前
将 rke2 集群证书延长至 10 年
运维·服务器·数据库
Yang96119 小时前
多功能一体化,成都鼎讯 LDMN-JM1 满足石油煤矿设备检定与训练需求
网络·能源
IP老炮不瞎唠9 小时前
Python 价格监控如何实现?思路与实用方法分享
运维·服务器·网络
睡不醒男孩03082310 小时前
CLup 6.x 版本中针对StarRocks 存算一体集群的完整操作手册
java·服务器·网络·clup
dog25010 小时前
网络长尾延时的重尾本质
开发语言·网络·php
Tokai_Teio_110 小时前
第四届黄河流域 misc
运维·服务器