TCP 连接终止:四次挥手

前提(全程以客户端和服务器为主机双方)

TCP 连接是全双工的,每个方向需独立关闭

即客户端到服务器的通道以及服务器到客户端到通道都需要进行关闭

本质

双工通道的独立关闭,确保数据完整性与资源安全释放。

简化过程

四次挥手步骤

  1. 主动方 FIN → 关闭己方发送通道
  2. 被动方 ACK → 确认关闭请求
  3. 被动方 FIN → 关闭己方发送通道
  4. 主动方 ACK → 确认最终关闭

步骤意义

第一次FIN + 第二次 ACK → 关闭客户端→服务端通道

第三次 FIN + 第四次 ACK → 关闭服务端→客户端通道

每个方向需单独确认(ACK),所以才需要挥手四次

且如果被动关闭方收到 FIN 后,但仍然有数据需要发送,就可以先发送 ACK 确认对方的关闭请求,而被动方的关闭请求可以等数据发送完后再进行发送,去要求关闭己方通道

图示

图以客户端为主动关闭方为例,黄色框为挥手后的状态变化:

为了需要关闭连接,需要在TCP段的段头中设置FIN标志。代表结束信号,FIN=1,和SYN=1、ACK=1的性质一下,代表着信号灯,告诉你这段TCP在干什么。

TCP段里携带的其他关键信息,都在另一篇TCP连接的文章里详细说过了。

相关场景

FIN 洪水攻击

  • 原理 :攻击者伪造 IP 发送大量 FIN,迫使服务端进入 LAST_ACK 状态并等待不存在的 ACK

  • 防御

    • 内核过滤非法 FIN(如校验序列号是否在窗口内)
    • 缩短 LAST_ACK 超时等待时间(Linux 默认 60s → 调至 20s)
相关推荐
程序员曦曦5 小时前
10:00开始面试,10:06就出来了,问的问题有点变态。。。
自动化测试·软件测试·功能测试·程序人生·面试·职场和发展
前端小巷子7 小时前
Vue 事件绑定机制
前端·vue.js·面试
是乐谷7 小时前
阿里云杭州 AI 产品法务岗位信息分享(2025 年 8 月)
java·人工智能·阿里云·面试·职场和发展·机器人·云计算
uhakadotcom7 小时前
开源:subdomainpy快速高效的 Python 子域名检测工具
前端·后端·面试
狂炫一碗大米饭8 小时前
事件委托的深层逻辑:当冒泡不够时⁉️
javascript·面试
AAA修煤气灶刘哥9 小时前
别再懵了!Spring、Spring Boot、Spring MVC 的区别,一篇讲透
后端·面试
Spider_Man9 小时前
面试官的 JS 继承陷阱,你能全身而退吗?🕳️
前端·javascript·面试
pepedd8649 小时前
探究js继承实现方式-js面向对象的基础
前端·面试·trae
似水流年流不尽思念10 小时前
Spring MVC 中的 DTO 对象的字段被 transient 修饰,可以被序列化吗?
后端·面试
似水流年流不尽思念10 小时前
为啥 HashMap 中的 table 也被 transient 修饰?其目的是什么?
后端·面试