为什么需要四次挥手

核心在于理解TCP连接的全双工特性。

简单来说:因为TCP连接是全双工的,它有两个独立的数据传输通道(A→B 和 B→A),每个方向必须单独关闭。


详细拆解四次挥手过程

假设客户端A主动关闭连接:

  1. 第一次挥手:FIN(A -> B)

    • A发送一个FIN=1的报文,表示"我没有数据要发送给你了"。
    • A进入 FIN_WAIT_1 状态,等待B的确认。
    • 此时,A到B的数据通道关闭,但B到A的通道仍然可用。
  2. 第二次挥手:ACK(B -> A)

    • B收到A的FIN后,立即回复一个ACK确认报文。
    • B进入 CLOSE_WAIT 状态。
    • 此时,A到B的通道确认关闭,B知道自己不会再收到A的数据,但B可能还有数据要发给A。
    • A收到这个ACK后,进入 FIN_WAIT_2 状态,等待B可能发来的FIN
  3. 第三次挥手:FIN(B -> A)

    • 当B把剩下的所有数据都发送给A后 ,B发送一个FIN=1的报文。
    • B进入 LAST_ACK 状态,等待A最后的确认。
  4. 第四次挥手:ACK(A -> B)

    • A收到B的FIN后,发送一个ACK确认报文。
    • A进入 TIME_WAIT 状态(等待2MSL时间,确保B收到了这个ACK,防止最后一个ACK丢失导致B无法正常关闭,等待 2MSL = 1MSL(我的ACK彻底失效) + 1MSL(你的重传FIN最大可能到达))。
    • B收到这个ACK后,连接彻底关闭 ,B进入 CLOSED 状态。
    • A在TIME_WAIT状态结束后,也进入 CLOSED 状态。

为什么不能像握手一样合并成三次?

这是面试官最可能追问的地方。关键在于 TCP的"半关闭"状态

  • 三次握手时 :B可以将SYN(建立请求)和ACK(对A请求的确认)合并发送,因为这两个动作发生在同一时刻
  • 四次挥手时
    • B收到A的FIN后,只能立即回复ACK,表示"我收到你的关闭请求了"。
    • 但此时B的应用层可能还有数据要处理并发送 ,因此B的FIN必须等所有数据都发送完毕后才能发出。
    • ACK是内核TCP协议栈立即回复的,而FIN是由应用层触发的,这两个事件在时间上是分离的,所以绝大多数情况下无法合并。

只有在一种极特殊的情况下,四次挥手可以变成三次 :当B收到A的FIN时,B也没有任何数据要发送了 ,那么B就可以将自己的ACKFIN合并成一个报文发送给A。但这属于TCP协议的优化,并非标准流程。


回答要点总结

"四次挥手是由TCP连接的全双工特性和半关闭状态决定的。"

  1. 全双工:连接有A->B和B->A两个独立通道,需要各自关闭。
  2. 核心过程 :主动关闭方(如客户端)先发FIN关闭自己的发送通道;被动关闭方先回ACK确认,然后在自己数据发送完毕后,再发FIN关闭自己的发送通道;最后主动方回ACK确认。
  3. 为什么是四次 :被动方的ACKFIN通常无法合并发送 。因为ACK是协议栈立即回复的,而FIN需要等待应用层所有数据发送完毕,两者存在时间差,这就产生了"半关闭"状态。
  4. 对比握手 :三次握手时,服务端的SYNACK都是针对连接建立的,可以同时发出,所以能合并。
相关推荐
猫头虎4 小时前
如何在浏览器里体验 Windows在线模拟器:2026最新在线windows模拟器资源合集与技术揭秘
运维·网络·windows·系统架构·开源·运维开发·开源软件
不一样的故事1265 小时前
下的 “Wi-Fi参数配置” 列表,但您当前选中的导航菜单项是 “IP规划”。您遇到的 “IP加载不出来” 问题,很可能
网络协议·tcp/ip·华为
古城小栈6 小时前
Rust 网络请求库:reqwest
开发语言·网络·rust
qq_316837759 小时前
IP网段冲突 配置指定ip使用指定的网络接口发送,而不经过默认网关
服务器·网络·tcp/ip
布史9 小时前
Tailscale虚拟私有网络指南
linux·网络
枷锁—sha10 小时前
彻底解决 Google Gemini 报错:异常流量与 IP 地址冲突排查指南
网络·网络协议·tcp/ip
Xの哲學10 小时前
深入剖析Linux文件系统数据结构实现机制
linux·运维·网络·数据结构·算法
-To be number.wan11 小时前
经典真题精讲|2010年408统考第34题:文件传输最少需要多久?
网络·计算机网络
逐梦苍穹11 小时前
不用公网 IP,把内网服务安全发布到公网:ZeroNews 快速上手
网络协议·tcp/ip·安全·内网穿透
知乎的哥廷根数学学派12 小时前
基于多尺度注意力机制融合连续小波变换与原型网络的滚动轴承小样本故障诊断方法(Pytorch)
网络·人工智能·pytorch·python·深度学习·算法·机器学习