计算机网络基础

windows 上 netstat -ano

linux netstat -anp

TCP 的"三次握手"和"四次挥手"是网络通信中最经典的设计,也是面试必考题。既然你有编程基础,我把这两个过程背后的核心逻辑 拆解给你看,不仅仅是流程,更是为什么必须这样设计

一、 三次握手(建立连接)

核心目的防止历史重复连接请求造成资源浪费 ,并同步双方的初始序列号711。

1. 过程回顾(客户端 -> 服务器)
  1. 第一次SYN=1, seq=x (客户端说:我要连你,我的序号是x)
  2. 第二次SYN=1, ACK=1, seq=y, ack=x+1 (服务器说:收到,我也连你,我的序号是y,期待你下个发x+1)
  3. 第三次ACK=1, seq=x+1, ack=y+1 (客户端说:收到,期待你下个发y+1)
2. 为什么必须是三次?(关键)

问:为什么不能是两次?

这是最常问的。如果只有两次(客户端发SYN,服务器回SYN+ACK就结束):

  • 场景:客户端发了一个SYN,但网络拥堵了,迟迟没到。客户端等超时了,又发了一个新的SYN。
  • 结果 :后来网络通畅了,那个旧的、迟到的SYN突然到了服务器。
  • 如果是两次握手:服务器以为是新请求,直接回一个SYN+ACK,连接就建立了!但客户端根本没发这个旧请求,不会理服务器。服务器就会白白浪费资源(半开连接)等待,甚至被攻击(SYN Flood)35。
  • 三次握手的解决 :服务器收到旧SYN后,虽然回了SYN+ACK,但客户端发现这不是我想要的连接,就不会发第三次ACK。服务器等一会没收到ACK,连接就自动断了24。

问:为什么不是四次?

因为第二次握手时,服务器的 SYN(同意连接)和 ACK(确认收到客户端请求)可以合并成一个包发出去3。既然能合并,就没必要拆成两次通信,三次是效率和安全的最优解17。

二、 四次挥手(断开连接)

核心目的全双工通信的双向关闭,确保数据不丢失45。

1. 过程回顾(以客户端主动关闭为例)
  1. 第一次FIN=1, seq=u (客户端说:我发完了,要关这一头了)
  2. 第二次ACK=1, seq=v, ack=u+1 (服务器说:收到,我这边还剩点数据要发,你先等着)
  3. 第三次FIN=1, seq=w, ack=u+1 (服务器说:我也发完了,关我这头)
  4. 第四次ACK=1, seq=u+1, ack=w+1 (客户端说:收到,连接彻底断了)
2. 为什么必须是四次?(关键)

问:为什么断开要四次,不能像握手那样合并?

因为 TCP 是全双工的(就像双向车道)5。

  • 双向独立 :客户端说"我不发了"(FIN),只是关了客户端到服务器 的车道。但服务器到客户端的车道还是通的,服务器可能还有数据没发完。
  • 不能合并的原因 :服务器收到客户端的 FIN 后,必须立刻回一个 ACK(这是第二次挥手),告诉客户端"我知道你发完了"。但是,服务器不能立刻发 FIN,因为它可能还在发数据给你。等服务器把剩下的数据发完了,才能发 FIN(第三次挥手)45。
  • 总结 :因为ACK (确认收到关闭请求)和FIN(我也要关闭)通常不是同时发生的,所以必须分两次发,总共就是四次。

问:为什么要有 TIME_WAIT 状态(等待 2MSL)?

客户端发完最后一次ACK后,不能直接消失,要等一阵子。原因有两个:

  1. 防止丢包:如果最后一次ACK丢了,服务器会重传FIN。客户端等着,就能收到重传的FIN并回复ACK,确保服务器正常关闭9。
  2. 防止旧连接干扰:等待一段时间,让网络里所有属于这个连接的旧数据包都消失,避免它们干扰新建立的连接89。

总结对比表

表格

特性 三次握手 (建立) 四次挥手 (断开)
核心目的 同步序列号,防止旧连接干扰 双向关闭,确保数据不丢失
为什么是这个次数 两次不安全(资源浪费),四次多余 因为全双工,ACK和FIN通常不能合并
关键标志位 SYN (同步), ACK (确认) FIN (结束), ACK (确认)
类比 打电话:"喂?""在711。""在。" 挂电话:"我说完了7。""好。""我也说完了。""好。"
相关推荐
网络研究院15 天前
2026年网络安全
网络·安全·法律·法规·趋势·发展
酣大智15 天前
ARP代理--工作原理
运维·网络·arp·arp代理
treesforest15 天前
AI安全系统如何识别异常访问?IP风险识别正在成为关键能力
网络·人工智能·tcp/ip·安全·web安全
shushangyun_15 天前
2026年快消品B2B系统推荐:支持终端门店订货、促销政策自动化的工具?
java·运维·网络·数据库·人工智能·spring·自动化
2601_9618451515 天前
粉笔行测题库|系统班|刷题
网络·百度·微信·微信公众平台·facebook·新浪微博
程序猿阿伟15 天前
《Chrome离线扩展安装的底层逻辑与场景落地指南》
服务器·网络·chrome
InHand云飞小白15 天前
无人值守站点网络困境?工业级路由器IR315破解连接难题
网络·物联网·4g·工业路由器·4g路由器·iiot·蜂窝路由器
森G15 天前
75、服务器源码解析---------云视频服务项目
linux·服务器·网络·c++·qt
江华森15 天前
TCP/IP 协议栈实战 — 7 个实验详解
网络·tcp/ip·智能路由器
酉鬼女又兒15 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php