当前位置: 首页 > news >正文

TCP 三次握手与四次挥手笔记

一、TCP 三次握手(建立连接)

TCP 是面向连接的、可靠的传输层协议,为了建立可靠的连接,TCP 采用三次握手(Three-way Handshake)机制。

1.1 三次握手过程

次数发送方接收方说明
第一次握手发送 SYN=1,seq=x客户端发送连接请求,进入 SYN_SEND 状态
第二次握手发送 SYN=1,ACK=1,seq=y,ack=x+1服务器收到请求,确认后进入 SYN_RCVD 状态
第三次握手发送 ACK=1,seq=x+1,ack=y+1客户端收到确认,进入 ESTABLISHED 状态,服务器收到后也进入 ESTABLISHED

1.2 报文示意图

客户端                             服务器| ----------- SYN ------------> || <-------- SYN + ACK --------- || ----------- ACK ------------> |
连接建立

1.3 握手各个阶段详解

  • 第一次握手
    客户端发送一个带 SYN 标志的数据包,表示请求建立连接,包内包含初始序列号 seq = x

  • 第二次握手
    服务器收到 SYN 包,确认(ACK)客户端的 SYN,同时发送自己的 SYN,seq = yack = x+1

  • 第三次握手
    客户端收到 SYN+ACK,发送 ACK 确认,ack = y+1

连接正式建立,双方可以开始数据传输了。


二、为什么需要三次握手?

  • 防止历史连接请求造成的错误连接(防止旧的重复连接初始化请求报文被服务器误处理)。
  • 确认双方的接收与发送能力均正常。
  • 确认客户端的初始序列号,服务器的初始序列号。

三、TCP 四次挥手(释放连接)

TCP 连接释放采用四次挥手(Four-way Handshake)机制,目的是保证双方都能彻底释放连接,避免数据丢失。

3.1 四次挥手过程

次数发送方接收方说明
第一次挥手发送 FIN=1,seq=u客户端请求关闭连接,进入 FIN_WAIT_1
第二次挥手发送 ACK=1,ack=u+1服务器确认关闭请求,进入 CLOSE_WAIT,客户端进入 FIN_WAIT_2
第三次挥手发送 FIN=1,seq=v服务器准备关闭,通知客户端
第四次挥手发送 ACK=1,ack=v+1客户端确认,进入 TIME_WAIT,服务器关闭,最后客户端关闭

3.2 报文示意图

客户端                             服务器| ----------- FIN ------------> || <----------- ACK ------------ || <----------- FIN ------------ || ----------- ACK ------------> |
连接关闭

3.3 各阶段详解

  • 第一次挥手
    客户端主动发送 FIN,表示不再发送数据,进入 FIN_WAIT_1

  • 第二次挥手
    服务器收到 FIN,返回 ACK,进入 CLOSE_WAIT,客户端进入 FIN_WAIT_2

  • 第三次挥手
    服务器处理完剩余事务后,发送 FIN,通知客户端,进入 LAST_ACK

  • 第四次挥手
    客户端确认后,进入 TIME_WAIT,等待 2MSL 后,最终关闭。


四、为什么需要四次挥手?

  • TCP 是全双工通信,关闭需要双方单独关闭各自的发送方向。
  • 第二次挥手后,服务器可能还有数据未发送完,不能直接关闭,需等待全部发送完成才发 FIN。

五、TIME_WAIT 状态及意义

  • 保证最后一个 ACK 能被对方接收到(如果丢失,服务器会重发 FIN)。
  • 防止旧连接中的延迟数据影响新连接。
  • 通常等待时间是 2 倍的 MSL(Maximum Segment Lifetime)。

六、状态迁移图(简化版)

客户端状态:
CLOSED -> SYN_SENT -> ESTABLISHED -> FIN_WAIT_1 -> FIN_WAIT_2 -> TIME_WAIT -> CLOSED服务器状态:
CLOSED -> LISTEN -> SYN_RCVD -> ESTABLISHED -> CLOSE_WAIT -> LAST_ACK -> CLOSED

七、总结对比

建立连接断开连接
三次握手四次挥手
双方都需要确认对方双方都需要关闭发送功能
主要防止失效连接请求确保数据完整可靠传输

八、附加 — 常见面试考点

  • 为什么不是两次握手?
    防止失效的连接请求导致的伪连接。

  • 为什么不是三次挥手?
    因为连接是双向的,必须双方都关闭发送端。

  • TIME_WAIT 为什么必须有?
    确保可靠性,避免延迟包干扰。

  • 如果客户端 TIME_WAIT 太多怎么办?

    • 调整操作系统参数,缩短 TIME_WAIT 时间
    • 使用连接复用(如 HTTP Keep-Alive)
http://www.xdnf.cn/news/1130779.html

相关文章:

  • 前端vue3获取excel二进制流在页面展示
  • Promise与Axios:异步编程
  • sqli-labs靶场通关笔记:第23关 注释符过滤
  • React -自定义hooks - 封装双向数据绑定
  • 自动控制原理知识地图:舵轮、路径与导航图
  • 2025年C++后端开发高频面试题深度解析:线程安全LRU缓存设计与实现
  • C# StringBuilder源码分析
  • 2025年Java最新社招面试八股文+技术场景题(金九银十)
  • Hadoop架构演进:从1.0到2.0的深度对比与优化解析
  • Hadoop(二)
  • QT技巧之快速搭建串口收发平台
  • Taro.getRandomValues() 用法详解
  • 有哪些好用的原型设计软件?墨刀、Axure等测评对比
  • Elasticsearch+Logstash+Kibana部署
  • Taro.eventCenter 用法详解与实战
  • 深入核心:理解Spring Boot的三大基石:起步依赖、自动配置与内嵌容器
  • 【Qt+error】error: use of undeclared identifier ‘MainWindow
  • uniapp各端通过webview实现互相通信
  • qt 中英文翻译 如何配置和使用
  • Spring AI 系列之十三 - RAG-加载本地嵌入模型
  • 在 CentOS 8 上彻底卸载 Kubernetes(k8s)
  • k8s之持久化存储流程
  • JavaScript 异步编程的终极指南:从回调到 Promise、Async/Await
  • 深入解析Linux进程地址空间与虚拟内存管理
  • vivo S30评测:用设计诠释科技,以性能书写情怀
  • 电脑安装 Win10 提示无法在当前分区上安装Windows的解决办法
  • openEuler 22.03 LTS Rootless Docker 安装指南
  • Apache IoTDB(1):时序数据库介绍与单机版安装部署指南
  • 免费MCP服务:Excel CSV 转 JSON MCP by WTSolutions 文档
  • 计算机网络:(九)网络层(下)超详细讲解互联网的路由选择协议、IPV6与IP多播