Linux35 TCP状态转换图

TCP状态转换图

这张图是TCP 状态转移图,完整展示了 TCP 连接从 "建立→通信→断开" 的全生命周期状态变化,每个状态和箭头对应实际的 TCP 数据包交互(如 SYN、ACK、FIN 等标志位的收发)。以下是分层详解:

一、核心状态分类

TCP 连接的状态可分为建立阶段通信阶段断开阶段三大类,每个状态有明确的触发条件和行为:

阶段 状态列表 核心作用
建立阶段 CLOSED → LISTEN → SYN_SENT → SYN_RCVD → ESTABLISHED 完成三次握手,建立可靠的 TCP 连接
通信阶段 ESTABLISHED 双方通过 TCP 连接传输数据(如 HTTP 请求、文件内容)
断开阶段 FIN_WAIT_1 → FIN_WAIT_2 → CLOSING → TIME_WAIT → CLOSED(主动关闭);CLOSE_WAIT → LAST_ACK → CLOSED(被动关闭) 完成四次挥手,释放 TCP 连接

二、建立阶段(三次握手)

TCP 连接建立需经过三次数据包交互(SYN、SYN+ACK、ACK),对应状态转移如下:

  1. CLOSED → LISTEN

    • 触发条件:服务器程序被动打开(如启动 HTTP 服务,监听 80 端口)。
    • 行为:服务器进入 "监听" 状态,等待客户端的连接请求。
  2. CLOSED → SYN_SENT

    • 触发条件:客户端程序主动打开(如浏览器发起网页请求)。
    • 行为:客户端发送SYN 包(请求建立连接),进入 "SYN 已发送" 状态,等待服务器响应。
  3. LISTEN → SYN_RCVD

    • 触发条件:服务器收到客户端的SYN 包
    • 行为:服务器发送SYN+ACK 包(同步序列号 + 确认收到 SYN),进入 "SYN 已接收" 状态,等待客户端最终确认。
  4. SYN_SENT → ESTABLISHED

    • 触发条件:客户端收到服务器的SYN+ACK 包
    • 行为:客户端发送ACK 包(确认收到 SYN+ACK),三次握手完成,双方进入 "已建立" 状态,可开始传输数据。

三、通信阶段(ESTABLISHED)

  • 状态:ESTABLISHED
  • 行为:客户端与服务器通过 TCP 连接双向传输数据(如客户端发 HTTP GET 请求,服务器发 HTML 响应)。
  • 关键:此状态下,双方通过 ** 序列号(Seq)确认号(Ack)** 保证数据的可靠传输(丢包重传、乱序重组)。

四、断开阶段(四次挥手)

TCP 连接断开需经过四次数据包交互(FIN、ACK、FIN、ACK) ,分为主动关闭被动关闭两条路径:

路径 1:主动关闭方的状态转移(客户端或服务器主动发起断开)
  1. ESTABLISHED → FIN_WAIT_1

    • 触发条件:主动关闭方发送FIN 包(请求断开连接)。
    • 行为:进入 "FIN 等待 1" 状态,等待对方的 ACK 确认。
  2. FIN_WAIT_1 → FIN_WAIT_2

    • 触发条件:收到对方的ACK 包(确认收到 FIN)。
    • 行为:进入 "FIN 等待 2" 状态,等待对方的 FIN 包(对方的断开请求)。
  3. FIN_WAIT_2 → TIME_WAIT

    • 触发条件:收到对方的FIN 包
    • 行为:发送ACK 包(确认收到 FIN),进入 "时间等待" 状态(持续 2MSL,约 1-4 分钟),确保对方收到最终 ACK,避免残留数据包干扰新连接。
  4. TIME_WAIT → CLOSED

    • 触发条件:时间等待超时(2MSL 结束)。
    • 行为:彻底释放连接资源,回到初始状态。
路径 2:被动关闭方的状态转移(对方主动发起断开,自身被动响应)
  1. ESTABLISHED → CLOSE_WAIT

    • 触发条件:收到对方的FIN 包(对方请求断开)。
    • 行为:发送ACK 包(确认收到 FIN),进入 "关闭等待" 状态,此时应用层需处理剩余数据并发起自身的断开请求。
  2. CLOSE_WAIT → LAST_ACK

    • 触发条件:应用层完成数据处理,发送FIN 包(自身的断开请求)。
    • 行为:进入 "最后确认" 状态,等待对方的 ACK 确认。
  3. LAST_ACK → CLOSED

    • 触发条件:收到对方的ACK 包(确认收到 FIN)。
    • 行为:彻底释放连接资源,回到初始状态。

五、特殊状态与异常处理

  • SYN_RCVD → LISTEN:若服务器收到 RST 包(复位请求),则从 "SYN 已接收" 回退到 "监听" 状态,表示连接建立被中断。
  • SYN_SENT → CLOSED:若客户端发起连接后超时未收到响应,或收到 RST 包,会从 "SYN 已发送" 回到 "关闭" 状态,终止连接建立。
  • CLOSING 状态 :若双方同时发起 FIN 请求,则会进入 "CLOSING" 状态,互相发送 ACK 后进入 TIME_WAIT,属于特殊的 "同时关闭" 场景。
相关推荐
Kapibalapikapi15 分钟前
工具 | netcat, netstat
网络·笔记·逆向
福尔摩斯张15 分钟前
基于C++的UDP网络通信系统设计与实现
linux·c语言·开发语言·网络·c++·tcp/ip·udp
北京耐用通信1 小时前
终结混合网络调试噩梦:耐达讯自动化实现EtherCAT对DeviceNet设备的直接读写
网络·人工智能·物联网·网络协议·自动化·信息与通信
Henry Zhu1231 小时前
VPP中的DPDK插件源码详解第一篇:DPDK插件的作用和意义以及整体架构
运维·服务器·网络·计算机网络·云原生
分***82 小时前
新版局域网IP扫描神器IPScanner.exe 绿色版V1.28.2,支持跨网段扫描_端口扫描_系统端口查看工具
网络·tcp/ip·端口扫描·ipscanner·局域网扫描
千天夜2 小时前
文件系统磁盘块分配方式:从隐式链接到索引结构
网络·网络协议
2501_915918412 小时前
HTTPS 端口深度解析,443 并不是唯一入口,理解 TLS 流量行为与抓包策略
网络协议·http·ios·小程序·https·uni-app·iphone
嘻哈baby3 小时前
游戏/远程桌面的网络延迟优化:从TCP拥塞控制到智能选路
网络·tcp/ip·游戏
shcoc3 小时前
备用 申请acme 申请ssl
网络·网络协议·ssl
网络小白不怕黑3 小时前
Docker容器网络:从容器互联到跨主机通信
网络·docker·容器