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关闭四次挥手
为什么要四次挥手?
确保数据能够完整传输。
当被动方收到主动方的FIN报文通知时,它仅仅表示主动方没有数据再发送给被动方了。
但未必被动方所有的数据都完整的发送给了主动方,所以被动方不会马上关闭SOCKET,它可能还需要发送一些数据给主动方后,
再发送FIN报文给主动方,告诉主动方同意关闭连接,所以这里的ACK报文和FIN报文多数情况下都是分开发送的。
不过在某些特殊情况里,也有三次或五次挥手,四次挥手只是在一般的正常情况下。
TCP报文格式图:
上图中有几个字段需要重点介绍下:
(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运维部落立场,如若转载,请注明出处:http://www.178linux.com/97287