TCP三次握手、四次挥手
TCP在传输之前会进行三次沟通,称为“三次握手”,传完数据断开的时候要进行四次沟通,一般称为“四次挥手”。
两个序号和三个标志位:
(1)序号:seq序号,占32位,用于标识从TCP源端发送的字节流,发送方发送数据时对此进行标记。
(2)确认序号:ack序号,占32位,只有ACK标志位为1时,确认序号字段才有效,ack=seq+1。
(3)标志位:共6个,即URG、ACK、PSH、RST、SYN、FIN等,具体含义如下:
(A)URG:紧急指针(urgent pointer)有效
(B)ACK:确认序号有效
(C)PSH:接收方应该尽快将这个报文交给应用层
(D)RST:重置连接
(E)RST:发起一个新连接。
(F)FIN:释放一个连接。
需要注意的是:
(A)不要将确认序号ack与标志位中的ACK搞混了。
(B)确认方ack=发起方req+1,两端配对。
三次握手:
(1)在第一次消息发送中,A随机选区一个序列号作为自己的出事序号发送给B;
(2)第二次消息B使用ack对A的数据包进行确认,因为已经收到了序列号为x+1的包,所以ack=x+1,同时B告诉A自己的初始化序列号,就是seq=y;
(3)第三条消息A告诉B收到了B的确认消息并建立连接,A自己词条消息的序列号是x+1,所以seq=x+1,而ack=y+1是表示A正准备接受B序列号为y+1的数据包。
为什么A还要发送一次确认呢? 这主要是为了防止已失效的连接请求报文段突然又传送到了B,因而产生错误。
四次挥手:
由于TCP连接时全双工的,因此,每个方向都必须要单纯进行关闭,这一原则是当一方完成数据发送任务后,发送一个FIN来终止这一方向的连接。收到一个FIN只是意味着这一方向上没有数据流动了,既不会再收到数据了,但是这个TCP连接上仍然能够发送数据,直到这一方向也发送了FIN。
首先进行关闭的一方将执行主动关闭,而另一方则执行被动关闭,,上图描述即使如此。
(1)第一次挥手:Client发送一个FIN,用来关闭CLient到Server的数据传送,Client进入FIN_WAIT_1状态。
(2)第二次挥手:Server收到FIN后,发送一个ACK给Client,确认序号为收到序号+1(与SYN相同,一个FIN占用一个序号),Server进入CLOSE_WAIT状态。
(3)第三次挥手:Server发送一个FIN,用来关闭Server到Client的数据传送,Server进入LAST_ACK状态。
(4)第四次挥手:Client收到FIN后,CLient进入TIME_WAIT状态,接着发送一个ACK给Server,确人序号为收到序号+1,Server进入了CLOSED状态,完成四次挥手。
此文章摘自 老王子 https://www.cnblogs.com/laowz/p/6947539.html