简述一下TCP三次握手四次挥手

TCP,名为传输控制协议,是一种可靠的传输层协议,IP协议号为6。

原则上任何数据传输都无法确保绝对可靠,三次握手只是确保可靠的基本需要。

TCP三次握手

无标题

TCP建立连接为什么是三次握手,而不是两次或四次?

个人理解:因为要双方都要确定对方的网络没毛病,通讯正常。

还有一个网上看到的说法,我觉得很有意思:

我:1+1等于几?

她:2,2+2等于几?

我:4

首先两个人约定协议

1.感觉网络情况不对的时候,任何一方都可以发起询问

2.任何情况下,若发起询问后5秒还没收到回复,则认为网络不通

3.网络不通的情况下等1min路由器之后再发起询问

对于我而言,发起 “1+1等于几”的询问后

1. 若5s内没有收到回复,则认为网络不通

2. 若收到回复,则我确认①我能听到她的消息 ②她能听到我的消息,然后回复她的问题的答案

对于她而言,当感觉网络情况不对的时候

1. 若没有收到我的询问,则她发起询问

2. 若收到“1+1等于几”,则她确认 ①她可以听到我的消息,然后回复我的问题的答案和她的问题“2,2+2等于几”

3. 若5s内没有收到我的回复“4”,则她确认 ②我听不见她的消息

4. 若5s内收到了我的回复“4”,则她确认 ②我可以听见她的消息

这样,如果上面的对话得以完成,就证明双方都可以确认自己可以听到对方的声音,对方也可以听到自己的声音!

TCP关闭四次挥手

111

为什么要四次挥手?

确保数据能够完整传输。

当被动方收到主动方的FIN报文通知时,它仅仅表示主动方没有数据再发送给被动方了。

但未必被动方所有的数据都完整的发送给了主动方,所以被动方不会马上关闭SOCKET,它可能还需要发送一些数据给主动方后,

再发送FIN报文给主动方,告诉主动方同意关闭连接,所以这里的ACK报文和FIN报文多数情况下都是分开发送的。

不过在某些特殊情况里,也有三次或五次挥手,四次挥手只是在一般的正常情况下。

TCP报文格式图:

222

上图中有几个字段需要重点介绍下:

(1)序号:Seq序号,占32位,用来标识从TCP源端向目的端发送的字节流,发起方发送数据时对此进行标记。

(2)确认序号:Ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,Ack=Seq+1。

(3)标志位:共6个,即URG、ACK、PSH、RST、SYN、FIN等,具体含义如下:

(A)URG(urgent):紧急指针(urgent pointer)有效。

(B)ACK(acknowledgement):确认序号有效。

(C)PSH(push):接收方应该尽快将这个报文交给应用层。

(D)RST(reset):重置连接。

(E)SYN(synchronous):发起一个新连接。

(F)FIN(finish):释放一个连接。

需要注意的是:

(A)不要将确认序号Ack与标志位中的ACK搞混了。

(B)确认方Ack=发起方Req+1,两端配对。

本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:/97287

发表评论

登录后才能评论

联系我们

400-080-6560

在线咨询:点击这里给我发消息

邮件:1823388528@qq.com

工作时间:周一至周五,9:30-18:30,节假日同时也值班

友情链接:万达直属  guoqibee.com  万达娱乐注册  华宇招商  万达娱乐注册  万达主管QQ  万达娱乐登录  万达娱乐直属  万达招商QQ  万达娱乐招商