如何理解TCP三次握手的过程

TCP三次握手是什么?

三次握手是TCP(传输控制协议)在建立连接时必须经历的一个过程,其核心目的是 确保通信双方都具有发送和接收数据的能力,并同步双方的初始序列号,为后续可靠的数据传输打下基础。

繁琐的语言文字真的是很难记住这些交互,我们可以从生活中的小故事进行加深理解

我们可以想象下我们打电话的场景,打电话前的确认流程会是这样:

复制代码
你说:"喂,听得到吗?" (发起连接)

对方回答:"听得到,你能听到我吗?" (确认收到,并回问)

你说:"我能听到,我们开始说吧。" (确认收到对方的回答)

至此,双方都确认了通信链路畅通,可以正式开始通话。

三次握手流程(核心)

握手阶段 发起方 核心报文(标志位) 作用/验证内容
第一次握手 客户端 → 服务器 SYN(同步序列编号) 客户端向服务器发起连接请求,携带初始序列号(seq=x); 验证:服务器确认"自己能接收客户端的报文"。
第二次握手 服务器 → 客户端 SYN + ACK(确认应答) 服务器响应连接请求,携带确认号(ack=x+1)和自己的初始序列号(seq=y); 验证:客户端确认"自己能发/收,服务器能收/发"。
第三次握手 客户端 → 服务器 ACK 客户端确认服务器的响应,携带确认号(ack=y+1); 验证:服务器确认"客户端能收,自己能发"。

验证阶段(核心目标:双向验证收发能力)

  1. 第一次握手验证:服务器仅能确认"客户端的发送能力正常,自己的接收能力正常",但客户端无法确认服务器的任何能力。
  2. 第二次握手验证
    • 客户端收到SYN+ACK后,确认"自己的发送/接收能力正常,服务器的接收/发送能力正常";
    • 服务器仅确认"客户端的发送能力正常,自己的接收能力正常",但无法确认客户端是否收到自己的响应。
  3. 第三次握手验证
    • 服务器收到ACK后,确认"客户端的接收能力正常,自己的发送能力正常";
    • 至此,双方确认彼此的收发能力均正常,TCP连接建立完成。

为什么需要三次握手?

  • 防止"失效的连接请求报文"被服务器接收,导致资源浪费(如客户端发送的连接请求延迟到达,服务器建立无效连接);
  • 三次握手是"双向验证"的最小次数(两次无法完成双向验证,四次冗余)。

核心目的总结

确认双方的发送和接收能力:通过"一发一收"的确认机制。

同步初始序列号:交换并确认彼此的初始序列号,这是实现TCP可靠传输(如数据排序、去重、流量控制)的基石。

防止旧连接初始化造成混乱:如上所述,避免网络中的延迟报文导致服务器错误地创建连接。


相关推荐
遇见你...7 分钟前
TypeScript
前端·javascript·typescript
Highcharts.js13 分钟前
Highcharts Grid 中文站正式上线:表格数据处理的全新选择
前端·javascript·数据库·表格数据·highcharts·可视化图表·企业级图表
阿正的梦工坊3 小时前
JavaScript 微任务与宏任务完全指南
开发语言·javascript·ecmascript
Lucis__5 小时前
一文读懂TCP通信机制:基于相关API构建可靠性连接
linux·网络·tcp/ip
PinTrust SSL证书6 小时前
IP地址访问网站,怎么去除不安全提示?
网络协议·tcp/ip·安全·网络安全·https·ssl
2301_799073027 小时前
基于 Next.js + 火山引擎 AI 的电商素材智能生成工具实战——字节跳动前端训练营成果
javascript·人工智能·火山引擎
kyriewen119 小时前
项目做了一半想重写?这套前端架构让你少走3年弯路
前端·javascript·chrome·架构·ecmascript·html5
(Charon)10 小时前
【C++/Qt】C++/Qt 实现 TCP Server:支持启动监听、消息收发、日志保存
c++·qt·tcp/ip
爱折腾的军哥11 小时前
首发 | OpenTaiji WFGY 防幻觉系统:让 AI Agent 不再"胡说八道"
javascript
颜酱11 小时前
从零实现「拍照记单词」小应用(可复刻版)
前端·javascript·人工智能