Interview AiBoxInterview AiBox 实时 AI 助手,让你自信应答每一场面试
请解释TCP三次握手的过程。
题型摘要
TCP三次握手是建立TCP连接的关键过程,通过三个步骤确保双方通信正常:1)客户端发送SYN包;2)服务器回复SYN-ACK包;3)客户端发送ACK包。这个过程同步了双方的序列号,验证了双方的收发能力,并避免了历史连接请求的干扰。三次握手完成后,双方进入ESTABLISHED状态,可以开始数据传输。
TCP三次握手详解
定义与目的
TCP(Transmission Control Protocol,传输控制协议)是一种面向连接的、可靠的传输层协议。在数据传输之前,通信双方需要先建立一个连接,这个过程就是三次握手。
三次握手的主要目的包括:
- 确保通信双方都具备发送和接收数据的能力
- 同步双方的序列号(Sequence Number)
- 交换TCP窗口大小等参数
- 建立可靠的通信连接
三次握手的详细步骤
第一次握手:客户端发送SYN包
- 客户端(主动发起连接方)向服务器发送一个SYN(Synchronize)包
- 包中包含:
- SYN标志位设置为1
- 初始序列号(ISN,Initial Sequence Number)设为客户端选择的随机值x
- 窗口大小等TCP选项
- 客户端进入SYN_SENT状态,等待服务器确认
第二次握手:服务器回复SYN-ACK包
- 服务器收到客户端的SYN包后,如果同意建立连接,会回复一个SYN-ACK包
- 包中包含:
- SYN标志位设置为1
- ACK标志位设置为1
- 确认号(Acknowledgment Number)设置为客户端序列号x+1
- 服务器自己的初始序列号设为服务器选择的随机值y
- 窗口大小等TCP选项
- 服务器进入SYN_RCVD状态,等待客户端的最终确认
第三次握手:客户端发送ACK包
- 客户端收到服务器的SYN-ACK包后,会发送一个ACK包
- 包中包含:
- ACK标志位设置为1
- 确认号设置为服务器序列号y+1
- 序列号设置为x+1(即第一次握手发送的序列号+1)
- 客户端进入ESTABLISHED状态,表示连接已建立
- 服务器收到这个ACK包后,也进入ESTABLISHED状态,此时连接建立完成,双方可以开始传输数据
为什么需要三次握手而不是两次或四次
为什么不是两次握手?
- 防止已失效的连接请求报文突然又传送到了服务器,从而产生错误
- 假设采用两次握手,客户端发送了一个SYN包,但因网络问题延迟了
- 客户端等待超时后,重新发送SYN包,建立连接,传输数据,然后关闭连接
- 此时,那个延迟的SYN包到达了服务器,服务器会误认为这是一个新的连接请求,发送SYN-ACK并建立连接,但客户端并不会响应,导致服务器资源浪费
- 三次握手可以确保客户端的发送和接收能力都正常,同时也能避免历史连接的干扰
为什么不是四次握手?
- 三次握手已经足够建立可靠的连接
- 第二次握手时,服务器将SYN和ACK合并为一个包发送,提高了效率
- 没有必要增加额外的握手次数,反而会增加连接建立的延迟
TCP三次握手过程中的状态转换
客户端状态转换
- CLOSED → SYN_SENT(发送SYN后)
- SYN_SENT → ESTABLISHED(收到SYN-ACK并发送ACK后)
服务器状态转换
- CLOSED → LISTEN(服务器启动,监听端口)
- LISTEN → SYN_RCVD(收到SYN并发送SYN-ACK后)
- SYN_RCVD → ESTABLISHED(收到ACK后)
可能的问题和异常情况
- SYN超时:客户端发送SYN后,如果在规定时间内没有收到服务器的SYN-ACK,会重传SYN
- SYN洪泛攻击:攻击者发送大量SYN包但不完成握手,耗尽服务器资源
- 半开放连接:一方完成了握手,另一方由于网络问题没有收到最后的ACK,导致资源浪费
总结
TCP三次握手是建立可靠连接的基础,通过这三个步骤,TCP协议确保了通信双方都准备好进行数据传输,并同步了必要的序列号信息。理解三次握手对于网络编程和故障排查都至关重要。
参考资料:
思维导图
Interview AiBoxInterview AiBox — 面试搭档
不只是准备,更是实时陪练
Interview AiBox 在面试过程中提供实时屏幕提示、AI 模拟面试和智能复盘,让你每一次回答都更有信心。
AI 助读
一键发送到常用 AI
TCP三次握手是建立TCP连接的关键过程,通过三个步骤确保双方通信正常:1)客户端发送SYN包;2)服务器回复SYN-ACK包;3)客户端发送ACK包。这个过程同步了双方的序列号,验证了双方的收发能力,并避免了历史连接请求的干扰。三次握手完成后,双方进入ESTABLISHED状态,可以开始数据传输。
智能总结
深度解读
考点定位
思路启发
相关题目
当在浏览器中输入URL并回车后,从网络层面到页面渲染的完整流程是怎样的?
从输入URL到页面渲染的完整流程分为网络请求和页面渲染两大阶段。网络请求包括URL解析、DNS解析、TCP连接建立(三次握手)、HTTP请求发送、服务器处理、HTTP响应返回和TCP连接断开(四次挥手)。页面渲染包括HTML解析构建DOM树、CSS解析构建CSSOM树、JavaScript执行、渲染树构建、布局(回流)、绘制(重绘)和图层合成。整个流程涉及多个网络协议和浏览器内部机制,了解这些流程有助于前端性能优化。
HTTP和HTTPS协议有什么区别?
HTTP和HTTPS的主要区别在于安全性。HTTP是超文本传输协议,以明文形式传输数据,不提供加密和身份验证,使用80端口。HTTPS是HTTP的安全版本,通过SSL/TLS协议提供数据加密、身份认证和数据完整性保护,使用443端口,需要SSL证书。HTTPS在安全性、信任度和SEO方面优于HTTP,但有一定的性能开销和证书成本。随着网络安全意识的提高,HTTPS已成为Web通信的标准。
请比较TCP和UDP协议的区别,以及它们各自的适用场景
TCP和UDP是传输层的两种核心协议。TCP是面向连接的可靠协议,提供数据完整性、顺序保证和流量控制,但速度较慢、资源消耗多,适用于Web浏览、文件传输、电子邮件等要求数据可靠性的场景。UDP是无连接的不可靠协议,传输速度快、资源消耗少,但不保证数据顺序和可靠性,适用于实时音视频、在线游戏、DNS查询等对实时性要求高的场景。选择哪种协议取决于应用对可靠性和实时性的需求权衡。
请解释TCP协议中的三次握手和四次挥手过程。
TCP协议中的三次握手和四次挥手是TCP连接建立和断开的关键过程。三次握手通过SYN、SYN+ACK和ACK三个报文交换建立连接,确保双方都准备好进行数据传输并同步序列号。四次挥手通过FIN、ACK、FIN和ACK四个报文交换断开连接,确保双方都完成了数据传输并优雅地关闭连接。三次握手防止了已失效连接请求的建立,而四次挥手则允许半关闭状态,确保数据完整传输。TIME_WAIT状态确保最后一个ACK能够到达对方,并允许旧报文段在网络中消失。
OSI七层网络模型分别包含哪七层?每层的主要功能是什么?
OSI七层网络模型从下到上分为物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。物理层负责比特流传输;数据链路层处理帧和MAC地址;网络层负责IP寻址和路由;传输层提供端到端的数据传输(TCP/UDP);会话层管理应用程序间的会话;表示层处理数据格式和加密;应用层直接为用户应用程序提供网络服务。每一层都有特定的功能和协议,共同协作实现网络通信。