Interview AiBox logo

Interview AiBox 实时 AI 助手,让你自信应答每一场面试

download免费下载
基础local_fire_department15 次面试更新于 2025-09-05account_tree思维导图

请解释TCP三次握手的过程。

lightbulb

题型摘要

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后)
--- title: TCP三次握手时序图 --- sequenceDiagram participant Client participant Server Note over Client,Server: 初始状态: CLOSED Client->>Server: SYN (seq=x) Note over Client: SYN_SENT Server->>Client: SYN-ACK (seq=y, ack=x+1) Note over Server: SYN_RCVD Client->>Server: ACK (seq=x+1, ack=y+1) Note over Client,Server: ESTABLISHED (连接建立完成)

可能的问题和异常情况

  • SYN超时:客户端发送SYN后,如果在规定时间内没有收到服务器的SYN-ACK,会重传SYN
  • SYN洪泛攻击:攻击者发送大量SYN包但不完成握手,耗尽服务器资源
  • 半开放连接:一方完成了握手,另一方由于网络问题没有收到最后的ACK,导致资源浪费

总结

TCP三次握手是建立可靠连接的基础,通过这三个步骤,TCP协议确保了通信双方都准备好进行数据传输,并同步了必要的序列号信息。理解三次握手对于网络编程和故障排查都至关重要。

参考资料:

account_tree

思维导图

Interview AiBox logo

Interview AiBox — 面试搭档

不只是准备,更是实时陪练

Interview AiBox 在面试过程中提供实时屏幕提示、AI 模拟面试和智能复盘,让你每一次回答都更有信心。

AI 助读

一键发送到常用 AI

TCP三次握手是建立TCP连接的关键过程,通过三个步骤确保双方通信正常:1)客户端发送SYN包;2)服务器回复SYN-ACK包;3)客户端发送ACK包。这个过程同步了双方的序列号,验证了双方的收发能力,并避免了历史连接请求的干扰。三次握手完成后,双方进入ESTABLISHED状态,可以开始数据传输。

智能总结

深度解读

考点定位

思路启发

auto_awesome

相关题目

当在浏览器中输入URL并回车后,从网络层面到页面渲染的完整流程是怎样的?

从输入URL到页面渲染的完整流程分为网络请求和页面渲染两大阶段。网络请求包括URL解析、DNS解析、TCP连接建立(三次握手)、HTTP请求发送、服务器处理、HTTP响应返回和TCP连接断开(四次挥手)。页面渲染包括HTML解析构建DOM树、CSS解析构建CSSOM树、JavaScript执行、渲染树构建、布局(回流)、绘制(重绘)和图层合成。整个流程涉及多个网络协议和浏览器内部机制,了解这些流程有助于前端性能优化。

arrow_forward

HTTP和HTTPS协议有什么区别?

HTTP和HTTPS的主要区别在于安全性。HTTP是超文本传输协议,以明文形式传输数据,不提供加密和身份验证,使用80端口。HTTPS是HTTP的安全版本,通过SSL/TLS协议提供数据加密、身份认证和数据完整性保护,使用443端口,需要SSL证书。HTTPS在安全性、信任度和SEO方面优于HTTP,但有一定的性能开销和证书成本。随着网络安全意识的提高,HTTPS已成为Web通信的标准。

arrow_forward

请比较TCP和UDP协议的区别,以及它们各自的适用场景

TCP和UDP是传输层的两种核心协议。TCP是面向连接的可靠协议,提供数据完整性、顺序保证和流量控制,但速度较慢、资源消耗多,适用于Web浏览、文件传输、电子邮件等要求数据可靠性的场景。UDP是无连接的不可靠协议,传输速度快、资源消耗少,但不保证数据顺序和可靠性,适用于实时音视频、在线游戏、DNS查询等对实时性要求高的场景。选择哪种协议取决于应用对可靠性和实时性的需求权衡。

arrow_forward

请解释TCP协议中的三次握手和四次挥手过程。

TCP协议中的三次握手和四次挥手是TCP连接建立和断开的关键过程。三次握手通过SYN、SYN+ACK和ACK三个报文交换建立连接,确保双方都准备好进行数据传输并同步序列号。四次挥手通过FIN、ACK、FIN和ACK四个报文交换断开连接,确保双方都完成了数据传输并优雅地关闭连接。三次握手防止了已失效连接请求的建立,而四次挥手则允许半关闭状态,确保数据完整传输。TIME_WAIT状态确保最后一个ACK能够到达对方,并允许旧报文段在网络中消失。

arrow_forward

OSI七层网络模型分别包含哪七层?每层的主要功能是什么?

OSI七层网络模型从下到上分为物理层、数据链路层、网络层、传输层、会话层、表示层和应用层。物理层负责比特流传输;数据链路层处理帧和MAC地址;网络层负责IP寻址和路由;传输层提供端到端的数据传输(TCP/UDP);会话层管理应用程序间的会话;表示层处理数据格式和加密;应用层直接为用户应用程序提供网络服务。每一层都有特定的功能和协议,共同协作实现网络通信。

arrow_forward

阅读状态

阅读时长

4 分钟

阅读进度

8%

章节:13 · 已读:1

当前章节: 定义与目的

最近更新:2025-09-05

本页目录

Interview AiBox logo

Interview AiBox

AI 面试实时助手

面试中屏幕实时显示参考回答,帮你打磨表达。

免费下载download

分享题目

复制链接,或一键分享到常用平台

外部分享