TCP三次握手的智慧:为什么不是两次或四次?

前一段时间我一个之前的同事,他问我知道TCP的三次握手吗?其实说实话我并不能说的那么明白,我问他你的事怎么回答的,他说光说了个三次握手的名字,然后面试官问为什么要握手三次,少握一次或者多握一次又问题吗?

那么我们今天就来分析分析这个问题?

一、三次握手

客户端和服务端两个端初次见面时的场景:

  1. 客户端发起请求 :主动说"你好!"(发送SYN报文
  2. 服务端确认并回应 :回答"收到了,你也好呀!"(发送SYN-ACK‌报文)
  3. 客户端最终确认 :回应"收到你说的:你要呀信息了"(发送ACK‌报文)

至此,双方均确认了彼此的发送能力和接收能力,可靠的双向通道建立完成。

关键点 :ACK(Acknowledgment)的本质是告知服务端"我收到了你之前发的某个数据"。第2步中服务端的SYN-ACK,既是对客户端SYN的确认(ACK),也是自己发起连接的请求(SYN)。

二、如果是两次握手的话

假设简化为两次握手(客户端SYN -> 服务端SYN-ACK即建立连接):

场景再现

  1. 客户端发送SYN(seq=100),假如说网络拥堵延迟
  2. 客户端超时重传SYN(seq=200),这次顺利到达,服务端响应SYN-ACK(ack=201),连接建立,正常通信后关闭。
  3. 此时,第一个迟到的SYN(seq=100)终于到达服务端!
  4. 服务端认为这是新请求,响应SYN-ACK(ack=101)并认为连接已建立
  5. 客户端收到此SYN-ACK,发现确认的序列号是101(它期望的是201或更新),会立刻回复RST(复位)包拒绝。
  6. 但服务端在收到RST之前,连接状态已是"已建立"。那么此时问题就来了:
    • 资源占用:服务端为该响应超时的连接分配了内存等资源。
    • 状态不一致 :服务端认为连接有效,客户端认为不存在。若服务端此时发送数据,客户端会以RST回应,但资源已被无意义占用

三次握手是如何解决的 :在第3步,客户端收到SYN-ACK后,能根据序列号判断这个连接请求是否过时 。如果是过时的请求,客户端不会发送ACK,服务端也就不会建立连接。服务端仅在收到有效的ACK后才真正建立连接状态

三、两次握手不行,那多握手一次应该可以吧?

这时候我们可能会想,两次不行,那就握四次,双向确认嘛,多好的然后就有了:

  • 客户端:SYN(我要连你)
  • 服务端:ACK(知道你连我)-> 确认了客户端的发送能力
  • 服务端:SYN(我也要连你)
  • 客户端:ACK(知道你也连我)-> 确认了服务端的发送能力

这样有什么问题吗?人家本来服务端的ACK和SYN可以放在一个报文里面发送,非要拆成两个

  1. 增加延迟:多了一次网络往返。
  2. 浪费资源:多处理一个报文。

四、所以三次握手是刚刚好的

  • 状态同步 :三次握手是通信双方可靠地同步初始序列号 的过程。初始序列号(ISN)用于标识字节流顺序,防止旧报文干扰新连接。双方必须确认对方知晓并认可自己的初始序列号。 三次设计是在效率、可靠性和资源安全之间找到的最小充分解,确保双方对连接状态达成唯一、一致的共识。

好了如果以后再面试中碰到这类问题,这样回答的话应该是可以的了!

相关推荐
Rust研习社8 分钟前
Weak 弱引用:如何用 Weak 打破 Rc 与 Arc 的循环引用
开发语言·后端·rust
贫民窟的勇敢爷们16 分钟前
Spring Boot+Vue电商系统开发实战:架构设计与核心实现
vue.js·spring boot·后端
m0_7381207227 分钟前
网路安全编程——熟悉并使用Scapy简单实现捕捉主流邮箱协议(SMTP、POP3和IMAP) 的身份凭证
网络·python·网络协议·tcp/ip·安全·网络安全
小码哥_常11 小时前
Spring Boot:别再重复造轮子,这些内置功能香麻了
后端
皮皮林55111 小时前
OpenFeign 首次调用卡 3 秒?八年老开发扒透 5 个坑,实战优化到 100ms!
后端
不会敲代码112 小时前
TCP/IP 与前端性能:从数据包到首次渲染的底层逻辑
前端·tcp/ip
千寻girling12 小时前
《 Git 详细教程 》
前端·后端·面试
0xDevNull14 小时前
Linux 中 Nginx 代理 Redis 的详细教程
redis·后端
GetcharZp14 小时前
告别 Nginx 手动配置!这款 Go 语言开发的云原生网关,才是容器化时代的真香神器!
后端
RuoyiOffice14 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
spring boot·后端·vue·anti-design-vue·ruoyioffice·假期·人力