【计网全栈通关】第 7 篇:传输层核心——TCP 连接管理、可靠传输与流量控制

0. 前言:进程通信的"守护神"

网络层(IP 协议)只负责把数据报从一台主机送到另一台主机,但它不保证"一定送到",也不管送到后给哪个程序。传输层(Transport Layer)则实现了进程到进程的逻辑通信。

本章我们将死磕传输层的王者------TCP 协议。它在不可靠的 IP 层之上,通过复杂的握手、确认和窗口机制,为应用层筑起了一道"可靠"的墙。

1. 传输层基本概念:端口与套接字

1.1 端口号 (Port)

端口号长 16 位,范围 0 \sim 65535。

  • 熟知端口 (0~1023): 分配给标准服务。

    • FTP: 21, SSH: 22, Telnet: 23, SMTP: 25

    • DNS: 53, HTTP: 80, HTTPS: 443

  • 注册端口 (1024~49151): 需按规定申请。

  • 动态端口 (49152~65535): 留给客户进程暂用。

1.2 套接字 (Socket)

套接字是传输层与应用层的接口。

套接字 Socket = (IP 地址 : 端口号)

408 考点: 每一条 TCP 连接唯一地被通信两端的两个端点(套接字)所确定。

2. TCP 报文段首部深度解析 ✨

TCP 报文不仅包含数据,其 20 字节的固定首部隐藏着连接控制的所有秘密。

字段 长度 功能
源/目的端口 各 16 位 确定收发端进程。
序号 (seq) 32 位 本报文段所发送数据的第一个字节的序号。
确认号 (ack) 32 位 期望收到对方下一个报文段的数据的第一个字节序号。
数据偏移 4 位 首部长度(以 4 字节为单位)。最大 15 \\times 4 = 60 字节。
控制位 (Flags) 6 位 URG, ACK, PSH, RST, SYN, FIN
窗口 (Window) 16 位 接收窗口 (rwnd),指明接收方目前允许对方发送的数据量。
校验和 16 位 检验范围包括首部、数据和伪首部(408 易混淆点)。

核心控制位说明:

  • ACK: 确认位。仅当 ACK=1 时确认号才有效。

  • SYN: 同步位。连接建立时用来同步序号。

  • FIN: 终止位。用于释放连接。

3. TCP 连接管理:三次握手与四次挥手 (408 核心图表)

3.1 三次握手 (Three-way Handshake)

目标:确认双方收发能力正常,同步初始序号 (ISN)。

  1. 第一步 (Client -> Server): SYN=1, seq=x。客户端进入 SYN-SENT 状态。

  2. 第二步 (Server -> Client): SYN=1, ACK=1, seq=y, ack=x+1。服务端进入 SYN-RCVD 状态。

  3. 第三步 (Client -> Server): ACK=1, seq=x+1, ack=y+1。客户端进入 ESTABLISHED。服务端收到后也进入 ESTABLISHED

💡 考研党深度思考:为什么不是两次握手? 为了防止失效的连接请求报文段突然又传送到了服务端,产生脏连接。两次握手只能保证服务端收到了请求,不能保证客户端知道服务端已经准备好了。

3.2 四次挥手 (Four-way Handshake)

由于 TCP 是全双工的,每个方向的连接必须单独释放。

  1. 第一步 (Client -> Server): FIN=1, seq=u。客户端进入 FIN-WAIT-1

  2. 第二步 (Server -> Client): ACK=1, ack=u+1, seq=v。服务端进入 CLOSE-WAIT(半关闭),客户端进入 FIN-WAIT-2

  3. 第三步 (Server -> Client): FIN=1, ACK=1, ack=u+1, seq=w。服务端进入 LAST-ACK

  4. 第四步 (Client -> Server): ACK=1, ack=w+1, seq=u+1。客户端进入 TIME-WAIT

3.3 TIME-WAIT 状态的意义

客户端必须等待 2MSL (最长报文段寿命) 时间才能关闭。

  1. 保证可靠关闭: 确保最后一个 ACK 报文能到达服务端。

  2. 防止新旧报文混淆: 让本连接持续时间内产生的所有报文都从网络中消失。

4. TCP 可靠传输机制

TCP 通过以下四个手段在不可靠的 IP 网络上实现可靠性:

  1. 序号: 字节流编号。

  2. 确认: 确认号 ack=N 表示前 N-1 字节已收到。

  3. 重传:

    • 超时重传: 计时器超时未收到 ACK(RTO 算法计算)。

    • 冗余确认 (快速重传): 收到 3 个相同的 ACK,立即重传,不需等计时器。

  4. 校验和: 保证内容未受损。

5. TCP 流量控制 (Flow Control) ✨

流量控制是为了防止发送方发得太快,淹没接收方的缓冲区。

5.1 滑动窗口机制

  • rwnd (接收窗口): 接收方告知发送方自己还能收多少。

  • 公式: 发送方的窗口大小 = \\min(接收窗口 rwnd, 拥塞窗口 cwnd)

5.2 零窗口与持续计时器

若接收方告知 rwnd=0,发送方停止发送。

  • 风险: 死锁(接收方缓存空了发送通知,但通知丢了)。

  • 解决: 持续计时器。发送方定时发送一个 零窗口探测报文

🛠 考研与三级避坑指南

5.1 408 深度计算案例

5.2 三级网络技术必背

  • UDP 与 TCP 区别:

    • TCP: 面向连接、可靠、字节流、首部 20B、全双工。

    • UDP: 无连接、尽力而为、面向报文、首部 8B(源端口、目端口、长度、校验和)。

  • 常见协议对应关系:

    • 运行在 TCP 上:HTTP, FTP, Telnet, SMTP。

    • 运行在 UDP 上:DNS, SNMP, TFTP, DHCP。

总结

TCP 协议是计算机网络中逻辑最严密、设计最巧妙的部分。对于考研党,请务必背熟三次握手/四次挥手的所有报文段细节 ;对于三级党,请务必区分 UDP 和 TCP 的报文头长度及应用层协议对应关系

下一篇预告:【传输层·拥塞控制】。我们将讨论 TCP 如何感知网络拥堵,以及 408 必考的拥塞窗口曲线图。

版权声明:本文为【计网全栈通关】系列,转载请注明出处。

相关推荐
小李独爱秋2 小时前
计算机网络经典问题透视:数据流的平均速率,峰值速率和突发长度各表达什么意思?
网络·网络协议·计算机网络·安全·信息与通信
好奇心害死薛猫2 小时前
飞牛NAS_docker_easytier
网络·docker
市安2 小时前
nat模式下lvs规划与部署
服务器·网络·php
NewCarRen2 小时前
汽车电子开发中功能安全和网络安全工程流程的协调
网络·安全
SaaS_Product2 小时前
企业网盘可以在局域网使用吗?
网络·人工智能·云计算·saas
YYYing.2 小时前
【计算机网络 | 第九篇】计网之传输层(三)—— TCP的拥塞控制与连接管理
网络·网络协议·tcp/ip·计算机网络
LcVong2 小时前
基于C#实现斑马ZT411打印机TCP通讯与打印状态精准判定
网络·tcp/ip·c#
willhuo3 小时前
程序这东西,想的即使在完善,也有想不到的地方。。
linux·服务器·网络
EverydayJoy^v^3 小时前
RH134学习进程——三.分析与存储日志
运维·服务器·网络