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

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

相关推荐
效能革命笔记11 小时前
Gitee DevSecOps 智能版本管理:军工软件工厂的依赖治理与供应链安全方案
网络·安全·gitee
darkdragonking11 小时前
由一次构建 OpenEuler 22.03 dnf源所了解到的
linux·运维·服务器
WUYOUGYLU11 小时前
云服务器怎么选、怎么用,才不花冤枉钱
运维·服务器
不昀11 小时前
VOOHU沃虎:音频变压器的匝数比和阻抗比如何换算?
网络·音视频·以太网·网络通信·电子元器件
小明同学0111 小时前
C++后端项目:统一大模型接入 SDK(四)
服务器·开发语言·c++·计算机网络·chatgpt
yqcoder11 小时前
数据的“包装方式”:深入解析 HTTP Content-Type
网络·网络协议·http
曦夜日长11 小时前
Linux系统篇,开发工具(五):git的基本使用和浅层认识
linux·运维·服务器
Harm灬小海11 小时前
【云计算学习之路】学习Centos7系统-ROOT密码重置方法
linux·运维·服务器·学习·云计算
IT瑞先生11 小时前
企业云服务器选型分析
运维·服务器
安妮的小熊呢12 小时前
CRMEB开源商城系统 & 标准版系统(PHP)开发规范
开发语言·javascript·php