快速理解 TCP 的三次握手和四次挥手

前言

TCP 的三次握手和四次挥手是 TCP 协议的常见考点,下面我们通过一张图和几条记忆点来快速理解。

TCP 连接传输状态图

三次握手

上图中最上面的红色部分就是三次握手。握手是双方刚见面的时候,所以是用来建立连接的。

第一次握手:客户端发送 SYN 报文给服务端。客户端发起请求,所以先打招呼。

第二次握手:服务端发送 SYN + ACK 报文给客户端。服务端收到了请求,向客户端回应,并表示收到了之前的请求。

第三次握手:客户端再发送 ACK 报文给服务端,表示也收到了服务端发来的报文。

SYN, ACK 等都是 TCP 特定的报文格式,就是特定的字节组合,具体大家可以不用深究。

为什么要三次握手?因为这是保证双方通信可靠性的最少次数。

客户端先向服务端发起第一次握手,类似于破冰,打开沟通的大门。服务端的第二次握手是为了回应客户端的第一次握手,向客户端表示:"我(服务端)能收到你(客户端)的报文",而客户端收到第二次握手后发起的第三次握手,也是为了回应服务端的第二次握手,是为了向服务端表示:"我(客户端)能收到你(服务端)的报文"。如果没有第三次握手,服务端就不确定:你(客户端)是否收到了我发出去的报文。

三次握手之后,双方都没有问题了,就可以开始通信了。

记忆点:

  1. 握手是为了建立连接
  2. 第一次握手是客户端发给服务端,为了破冰
  3. 第二次握手是服务端发给客户端,表示服务端能收到客户端发来的报文
  4. 第三次握手是客户端发给服务端,表示客户端能收到服务端发来的报文

四次挥手

上图中最下面的蓝色四个方框中就是四次挥手。挥手意味着告别,用于正常终止一个 TCP 连接。

第一次挥手,客户端发送 FIN 报文给服务端,表示我可以结束了。

第二次挥手,服务端发送 ACK 报文给客户端,表示服务端收到了客户端发来的结束报文。

第三次挥手,第二次挥手结束后,TCP 连接处于半关闭状态,这时客户端准备关闭连接了,但可能服务端还有数据没有发送完。等服务端将数据发送完毕后,服务端再发送 FIN 报文给客户端,表示服务端也可以结束了。

第四次挥手,客户端收到服务端的报文后,向服务端发送 ACK 报文,表示我收到了你发的结束报文,正式告别。

为什么要四次挥手?因为一方的数据发送完了,另一方可能还有数据要发送,双方都发送完,才能正式地告别。

客户端先向服务端第一次挥手,表示:"我(客户端)可以结束了",而服务端作为回应,向客户端发送了第二次挥手,表示:"我(服务端)知道了"。而后就是等待服务端把所有数据都发送给客户端之后,服务端再次向客户端发送第三次挥手,表示:"我(服务端)也可以结束了",客户端收到后,为表示礼貌(可靠),向服务端发送第四次挥手,表示:"我(客户端)也知道了"。

记忆点:

  1. 挥手是为了关闭连接
  2. 前两次挥手是客户端告知服务端可以结束了,服务端回应知道了
  3. 后两次挥手是服务端告知客户端可以结束了,客户端回应知道了

如果觉得有用,请点赞 + 收藏吧!

相关推荐
千天夜1 小时前
使用UDP协议传输视频流!(分片、缓存)
python·网络协议·udp·视频流
长弓三石2 小时前
鸿蒙网络编程系列44-仓颉版HttpRequest上传文件示例
前端·网络·华为·harmonyos·鸿蒙
xianwu5432 小时前
反向代理模块
linux·开发语言·网络·git
follycat2 小时前
[极客大挑战 2019]HTTP 1
网络·网络协议·http·网络安全
earthzhang20213 小时前
《深入浅出HTTPS》读书笔记(5):随机数
网络协议·http·https
xiaoxiongip6663 小时前
HTTP 和 HTTPS
网络·爬虫·网络协议·tcp/ip·http·https·ip
JaneJiazhao3 小时前
HTTPSOK:SSL/TLS证书自动续期工具
服务器·网络协议·ssl
JaneJiazhao3 小时前
HTTPSOK:智能SSL证书管理的新选择
网络·网络协议·ssl
CXDNW3 小时前
【网络面试篇】HTTP(2)(笔记)——http、https、http1.1、http2.0
网络·笔记·http·面试·https·http2.0
无所谓จุ๊บ4 小时前
树莓派开发相关知识十 -小试服务器
服务器·网络·树莓派