图解计算机网络:TCP协议三次握手与四次挥手
创作时间:
作者:
@小白创作中心
图解计算机网络:TCP协议三次握手与四次挥手
引用
CSDN
1.
https://blog.csdn.net/weixin_43889578/article/details/136087435
TCP协议三次握手与四次挥手
TCP协议的三次握手和四次挥手是网络通信中非常重要的概念,它们分别负责建立和断开TCP连接。下面将详细介绍这两个过程及其背后的原理。
三次握手流程
- 首先是客户端(也就是我们的浏览器)发送一个SYN标志位为1的请求报文,表示请求建立连接,此时客户端进入SYN-SENT状态;
- 然后服务器接收到之后会返回一个SYN和ACK标志位为1的报文,表示响应客户端的连接请求,并请求客户端建立连接,此时服务端进入SYN-RCVD状态;
- 最后客户端返回一个ACK标志位为1的报文,于是双方进入ESTABLISHED状态,表示连接建立成功。
为什么是三次握手,而不是两次或四次
- 三次握手可以防止历史连接建立请求导致的错误连接初始化。
比如我们有一个客户端向服务器发起握手请求,握手请求报文的seq num是90但是此时网络阻塞,导致握手请求的报文迟迟没有到达服务器。
然后我们重启了客户端,此时重新发送连接建立请求的报文,这次报文的seq num是100,此时网络通畅了,seq等于90的握手请求比seq等于100的握手请求先到达。
此时服务器会先响应一个ack等于91的响应报文,然后客户端接收到之后,会返回一个RST标志位为1的报文。RST标志位为1,表示这个连接要终止。
这样,服务器没有为这个错误的握手请求建立连接并初始化相应的资源。而是等到seq等于100的握手请求到达,走完三次握手,才会真正建立连接,并开始数据的传输。
如果现在两次握手就建立连接了,就会变成这样:
两次握手就建立了连接,服务端就会为这个连接初始化一系列资源,然后后面收到RST包后又终止连接,这就纯属资源浪费了。 - 三次握手才能确定双方的seq序列号。
首先客户端与服务器的一来回,可以确定客户端的序列号。
然后服务器到客户端的一来回,可以确定服务端的序列号。
第二次和第三次可以合为一次握手请求,于是三次握手请求就可以确定双方的序列号。
至于为什么不是四次、五次握手,那是因为三次就足够,三次握手已经可以处理历史连接建立的请求和确认双方的序列号,再多次数的握手就是多余的。
四次挥手流程
- 客户端发起断开连接请求(也可以是服务端断开连接请求),发送一个FIN标志位为1的报文,代表客户端请求断开连接,此时客户端的状态变成FIN_WAIT_1。
- 服务器接收到断开连接的请求报文后,返回一个ACK标志位位1的报文,此时服务端的状态变为CLOSE_WAIT。
- 客户端接收到响应报文之后,状态变成FIN_WAIT_2,然后等待服务端传输完剩下的数据后,发送FIN标志位为1的报文。
- 服务端等传输完数据后,就会发送一个FIN标志位为1的报文。
- 客户端接收到这个FIN标志位为1的报文后,会返回一个ACK标志位为1的报文,然后进入TIME_WAIT状态,等待两个MSL(报文最大生存时间),然后进入CLOSE状态,连接真正关闭。
- 服务端接收到客户端返回的这个FIN标志位为1的报文,就会进入CLOSE状态,连接关闭。
TIME_WAIT 为什么要等待 2MSL
当主动断开连接一方(也就是上面的client)最后一个ACK数据包发送的时候丢失了,被动断开连接一方(也就是上面的server)就会重新发送FIN报文。
等待2MSL目的就在于出现这种情况的时候,主动断开连接一方保证可以接收到被动断开连接一方重发的FIN报文。
如果等待的时长不足2MSL,那么就无法保证能够接收到被动断开连接一方重发的FIN报文;不等待更长的时间,那是因为如果此时网络不可靠,在2MSL时长内也无法让主动断开连接一方接收到被动断开连接一方重发的FIN报文,那么等待再长的时间也是没有意义的,比如现在是丢包率百分之一百的网络,等再长的时间也是白等。
为什么握手是三次,挥手是四次?
因为主动断开连接的一方发送断开连接的请求时,可以确定主动方已经没有数据需要传输了,但是无法确定被动断开连接一方是否已经没有数据需要发送。因此如果当被动方接收到主动方发送的FIN报文之后,返回一个ACK报文给主动方之后,还需要把剩下的数据发送完。
此时主动方虽然不能再发送数据,但是还可以响应ACK报文,所有还是可以接收被动方发送的数据。
本文原文来自CSDN,作者:weixin_43889578
热门推荐
智能家电选购与使用指南:科技赋能,提升生活幸福感
考古揭秘南宋临安城:一座南方山水都城的辉煌与沧桑
熬猪油加碗水,满满的小技巧,又香又白无异味
二手房买卖需缴纳的税由谁交
认购和申购有什么区别?这几点比较重要
GTX750Ti vs R9 370:性能对比、游戏表现全解析
网友:多吃水果,好处多多!中医师:这几类人群要注意
中医养生四大法则:从饮食到起居的全面调养指南
调薪申请人力资源怎么批
人工智能培训网站怎么选择适合自己的课程?
0基础如何转行人工智能
如何确诊冠心病?两种主要诊断方法详解
市场泡沫的形成原因是什么?如何防范市场泡沫的产生?
2025南京大学金融硕士考研复试攻略
IATF16949质量管理体系的适用范围是什么?
高尔夫球场维护指南:基本提示和清单
清蒸鲈鱼的5个关键制作要点
良性甲状腺结节会不会恶变?什么情况会变成癌?三甲医院专家告诉你
图谱丨手部的血管解剖:肌肉、走行
甲状腺疾病的健康宣教
减肥运动期间饮食应如何调节
交通事故诉讼时效起算时间是什么
《哈利·波特》中斯内普为何杀死邓布利多?
ROG降临2RGB耳机RGB灯效关闭方法详解
荷兰豆一般焯水几分钟?可不能煮久了!
上海一日游路线推荐:探索历史与现代交融
身份证上的生日是阴历还是阳历?
深圳龙华区富康社区(水斗富豪新村属于富康社区吗)
jlpt各题分数n1占比多少,每个部分需要考多少分
流行艺术中的消费主义:赞美还是批判?