赞
踩
首先我们要先清楚 TCP连接是在什么时间段发生的 当我们在浏览器地址输入栏输入了一段地址之后会有如下操作依次发生⬇️
从这张简略图可以看出来 建立TCP连接的时间段是在构建请求且缓存中不存在这一段域名之后产生的 其实 TCP 连接可以简单的概括为 三次握手、四次挥手 首先我们先来看一下 TCP头部
结构
其中在TCP连接
中我们最需要关注的几个地方就是 序列号、确认号还有标记位(SYN、FIN、ACK、RST…)
SYN = 1
时,表示希望创建连接。ACK = 1
时,确认号字段有效。FIN = 1
时,表示希望断开连接。RST = 1
时,表示TCP连接出现异常,需要断开。CLOSE
状态listen
状态Client_Num + 1
,SYN包 的值则是客户端这边随机出来的序列号,同时将 ACK 和 SYN 的标记位置为1,将报文发送到客户端,随机自己进入 SYN_RCVD 状态ACK
确认包,告诉服务端自己已经接收到了请求,其值为 server_num + 1
, 并且将 ACK标记位置为1 发送报文后自己进入 ESTABLISHED状态以上就是TCP三次握手的过程
这里我就用最简单的方式来告诉大家吧
第一次握手:客户端向服务端发送了网络包,服务端接收到了。可以证明⬇️
- 服务端知道了客户端的发送能力和服务端的接受能力是没有问题了
第二次握手:服务端的发包,客户端接收到了,此时可以证明⬇️
服务端知道了客户端的发送能力和服务端的接受能力是没有问题了
客户端知道 服务端的接受能力和发送能力没问题,自己的接受能力和发送能力没问题
但是此时的服务端不知道的是,自己发送的包客户端能不能接收到,也就是服务端无法确认自己的发送能力和客户端的接受能力是否正常 所以这个时候就需要 TCP 的第三次握手
- 第三次握手:客户端向服务端发包,服务端接收到了
- 此时的 服务端 就知道双方的发包能力和接受包的能力都是没问题的,也就建立起了TCP连接
答案是可以的 第三次握手的时候,由于客户端已经知道双方的发包已经收包能力都是正常的,就可以正常的发送数据了
首先我们还是用图来表示一下这个过程8⃣️
一开始的时候,服务端和客户端仍处于 ESTABLISHED
状态
客户端首先想要断开连接,这时就会向服务端发送一个**FIN
**报文,报文中有一个指定的序列号,表示想要断开链接,并且进入 FIN_SAIT_1 状态
此时服务端收到了由客户端发送来的FIN
包之后,会先给客户端发送一个 ACK
报文,报文的序列号为客户端的序列号值 + 1
,表示自己已经收到了,但是需要检查一下自己还有没有什么需要发送的资源,并且进入 CLOSE_WAIT状态
等到服务端检查完毕没有需要发送的资源之后,就会给客户端发送一个 FIN 包表示即将断开链接,并且进入 LAST_ACK 状态
客户端收到了 FIN 包之后,再次发送一个 ACK 报文,报文的序列号为服务端的序列号值 + 1
,表示自己已经收到,随机进入 TIME_WAIT 状态,等待2msl
之后,就进入了 CLOSE 状态
服务端接收到了来自客户端发送的 ACK 包之后,也进入了 CLOSE 状态
以上就是TCP四次挥手的全过程,你听明白了嘛~
数据残缺
了,避免这次 TCP
连接中的数据污染到下一次 TCP 连接Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。