频道栏目
首页 > 资讯 > 网络协议 > 正文

TCP为什么要三次握手而结束要四次

17-08-31        来源:[db:作者]  
收藏   我要投稿

TCP为什么要三次握手而结束要四次?

1、连接为什么3次握手

举个打电话的例子:

A : 你好我是A,你听得到我在说话吗

B : 听到了,我是B,你听到我在说话吗

A : 嗯,听到了

建立连接,开始聊天!

三次握手的过程如下所示:

这里写图片描述

简单而言:如果不是三次握手的话,那么到底需要几次握手最佳呢?2次握手?

先看2次握手的情况:

客户端给服务器发送建立连接的请求,服务器同意连接请求发回应给客户端,连接就此建立。

有问题的就是网络中经常会出现的包的延迟,如果客户端的某个包在路由器上延迟了,过了很久才发给服务器,服务器收到这个包后回应给客户端,服务器以为连接就此建立成功,分配资源,这样就会出现问题。

补充:

TCP三次握手,实际上是双方各握手一次,各做一次确认,其中一次握手和确认合并在一起。

2、为什么TCP协议终止连接要四次?

这里写图片描述

1、当主机A确认发送完数据且知道B已经接受完了,想要关闭发送数据口(当然确认信号还是可以发),就会发FIN给主机B。

2、主机B收到A发送的FIN,表示收到了,就会发送ACK回复。

3、但这是B可能还在发送数据,没有想要关闭数据口的意思,所以FIN与ACK不是同时发送的,而是等到B数据发送完了,才会发送FIN给主机A。

4、A收到B发来的FIN,知道B的数据也发送完了,回复ACK, A等待2MSL以后,没有收到B传来的任何消息,知道B已经收到自己的ACK了,A就关闭链接,B也关闭链接了。

A为什么等待2MSL,从TIME_WAIT到CLOSE?

在Client发送出最后的ACK回复,但该ACK可能丢失。Server如果没有收到ACK,将不断重复发送FIN片段。所以Client不能立即关闭,它必须确认Server接收到了该ACK。Client会在发送出ACK之后进入到TIME_WAIT状态。Client会设置一个计时器,等待2MSL的时间。如果在该时间内再次收到FIN,那么Client会重发ACK并再次等待2MSL。所谓的2MSL是两倍的MSL(Maximum Segment Lifetime)。MSL指一个片段在网络中最大的存活时间,2MSL就是一个发送和一个回复所需的最大时间。如果直到2MSL,Client都没有再次收到FIN,那么Client推断ACK已经被成功接收,则结束TCP连接。

相关TAG标签
上一篇:爬虫工程师和网络安全工程师的爱恨情仇
下一篇:Python基础整理操作积累
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站