三次握手
四次挥手
一.SYN,ACK,FIN,seq,ack各代表什么意思?
SYN:代表请求创建链接,所以在三次握手中前两次要SYN=1,表示这两次用于建立链接。
FIN:表示请求关闭链接,在四次分手时,FIN发了两遍,这是因为TCP的链接是双向的,所以一次FIN只能关闭一个方向。所以一次FIN只能关闭一个方向。
ACK:代表确认接受,不管三次握手和四次分手,在回应的时候都会加ACK=1,表示消息收到了,并且在建立链接以后的发送数据时,都会加上ACK=1,表示数据接收成功。
seq:序列号,当发送一个数据时,数据是被拆成多个数据包来发送,序列号就是对每个数据包进行编号,这样接收方才能对数据包进行再次拼接。
初序列号是随机生成的,这样不一样的数据拆包解包就不会连接错了。(例如:两个数据都被拆成1,2,3和一个数据是1,2,3一个是101,102,103,很明显后者不会连接错误)
ack:这个表示下一个数据包的编号,这也就是为什么第二次请求时,ack是seq+1
(总结:A,在创建连接时,1.客户端首先要SYN=1,表示要创建连接;2.服务端接受到请求后,要告诉客户端:我接受到了!所以加个ACK=1,就变成了ACK=1,SYN=1;3.理论上这时就创建连接成功了,但是为防止意外,客户端要再发一个消息给服务端确认下,这时只需要ACK=1就行了,即三次握手。
B,四次分手时,1.首先客户端请求关闭客户端到服务端方向的链接,这时客户端就要发送一个FIN=1,表示要关闭一个方向的链接;2.服务端接收到后确认下,即关闭了这个方向的链接,所以返回了一个ACK=1;3.这时只关闭了一个方向,另一个方向也需要关闭,所以服务端也向客户端发送了个FIN=1;4.客户端接收到后返回了个ACK=1,表示接受成功)
二.为什么要三次握手?
如果发送两次就可以链接的话,那么只要客户端发送一个链接请求,服务端接收到并发送了确认,就会建立一个链接。
可能出现的问题:如果一个链接请求在网络中跑的慢,超时了,这时客户端会从新发送请求,但是这个跑的慢的请求最后还是跑到了,然后服务端就接受了两个链接请求,然后全部回应就会创建两个链接,浪费资源。
如果加了第三次客户端确认,客户端在接受到一个服务端链接确认请求后,后面再接受到的链接确认就可以抛弃不管了。
三.为什么需要四次分手
TCP是双向的,所以需要在两个方向分别关闭,每个方向的关闭又需要请求和确认,所以一共就4次。