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

TCP断开通信前的四次挥手(为啥不是三次?)

1.四次握手的过程

  • 客户端A发送 FIN(终止连接请求)

    • A:我要断开连接了(FIN)。
    • A进入FIN_WAIT_1状态,表示请求断开,等待对方确认。
  • 服务器B回复 ACK(确认断开请求,但还未准备好关闭)

    • B:我收到了你的断开请求,但我还有数据要处理,你先等一下(ACK)。
    • B进入CLOSE_WAIT状态,A进入FIN_WAIT_2状态,A此时不会再发送数据,但会继续接收。
  • 服务器B处理完数据后,发送 FIN(关闭请求)

    • B:我也准备好断开了,我们可以关闭连接(FIN)。
    • B进入LAST_ACK状态,等待客户端的最终确认。
  • 客户端A回复 ACK(确认断开完成)

    • A:好的,连接断开(ACK),正式关闭连接。
    • A进入TIME_WAIT状态,等待一段时间确保B已收到ACK,之后真正关闭。B收到ACK后直接关闭连接。

2.为啥不是三次(确保数据完整交付)

假设三次挥手的流程如下:

  1. A 发送 FIN,请求关闭连接。
  2. B 立即发送 FIN+ACK,表示确认并关闭连接。
  3. A 直接关闭连接。

问题:

  • 由于B可能仍有未完成的数据需要发送,A的过早关闭会导致数据丢失。
  • B应该在确认A的请求(ACK)后,先完成自己要发送的数据,再主动请求关闭(发送 FIN)。
  • 三次挥手无法区分“确认收到断开请求 和 我也准备断开””这两个不同的操作,因此需要额外的一次握手。

总结:TCP 需要四次挥手,而不能三次的原因是:

  1. TCP是全双工通信,双方的发送和接收是独立的,必须各自关闭。
  2. 确保数据的完整性,避免提前关闭连接导致数据丢失。
  3. 防止“半关闭”状态时误断开,导致连接数据未完整发送。
http://www.lryc.cn/news/525085.html

相关文章:

  • win32汇编环境,按字节、双字等复制字符的操作
  • .net 项目引用与 .NET Framework 项目引用之间的区别和相同
  • RabbitMQ--延迟队列
  • 使用pyboard、micropython和tja1050进行can通信
  • JS学习之JavaScript模块化规范进化论
  • 亚博microros小车-原生ubuntu支持系列:7-脸部检测
  • 第二届国赛铁三wp
  • 缓存商品、购物车(day07)
  • 4【编程语言的鄙视链原因解析】
  • 美团一面面经
  • 什么是报文的大端和小端,有没有什么记忆口诀?
  • Spring中BeanFactory和ApplicationContext的区别
  • 期货行业专题|基于超融合实现 IT 基础设施现代化与国产化转型实践合集
  • AI新玩法:Flux.1图像生成结合内网穿透远程生图的解决方案
  • Jenkins-pipeline Jenkinsfile说明
  • vue3中为什么引入setup,引入setup是为了解决什么问题,setup的执行时机是什么?返回值是什么
  • Ubuntu 安装 docker 配置环境及其常用命令
  • 自动化01
  • 音频入门(二):音频数据增强
  • MySQL管理事务处理
  • MySQL数值型函数详解
  • 54.DataGrid数据框图 C#例子 WPF例子
  • 总结6..
  • 复位信号的同步与释放(同步复位、异步复位、异步复位同步释放)
  • Gartner发布2025年网络治理、风险与合规战略路线图
  • 基于STM32的智能空气质量监测与净化系统设计
  • 人工智能之数学基础:线性代数中的线性相关和线性无关
  • 08 工欲善其事必先利其器—常用类
  • Redis实战-初识Redis
  • spring boot中实现手动分页