TCP为什么是三次握手和四次挥手以及可能出现的问题
创始人
2024-05-15 12:05:35
0

目录

    • TCP为啥设定为三次握手(两个角度分析)
      • 不可靠
      • 产生无效链接浪费服务器资源
    • TCP为啥四次挥手
      • 服务端有剩余数据需要发送--四次挥手(多数情况)
      • 服务端无剩余数据发送--捎带应答--四次变三次(少数情况)
    • 四次挥手可能出现的问题
      • 可能出现大量的TIME_WAIT
      • 可能出现大量的CLOSE_WAIT

TCP为啥设定为三次握手(两个角度分析)

如果是4次,多了一次没啥意义还慢了,如果是两次握手逻辑可能存在下列问题:

(这两个方面也可以理解为握手过程中可能出现的问题)

不可靠

TCP协议是可靠的,那么建立的连接也需要确保是双向,可靠的; 根据连接过程分析,只有一方收到了另一方的ack确认报文,才能证明那一方的接收功能都正常。

举下面这个确认序号的例子说明 完整的接,收能力的重要性:

(这个抽象的接收功能,在下图握手过程中实际交换seq初始序号的过程中能体现)

在这里插入图片描述

第二次握手时,s端发完ack报文就默认进入establish建立成功状态,假设这个ack报文半路丢了呢?

c端压根就没有拿到ack也没有拿到s端的初始序号,显然这个链接是不可靠的!无法完成后续数据的交互;

产生无效链接浪费服务器资源

假定C端向S端发送了一个请求,但是该请求因为网络原因,在网路中逗留了一会儿,未及时送达。此时C将再次向S发送请求,Server接收到请求,发送确认包,完成连接并开始进行数据传输,直到数据传输完成后,断开连接。

之后,之前逗留的链接到了S端,这就尴尬了,S拿到syn请求,并回应了ACK应答,然后进入establish建立完成状态,这个链接无疑是不合法的,c端早已离去,剩下这个空连接,维持他消耗着S端的资源;

(c端:s端一般是n:1,如果存在上述问题,试想大量空连接有可能被维护,服务器资源会越来越吃紧从而导致更严重的问题)

TCP为啥四次挥手

客户端或服务器均可主动发起挥手动作,调用close()即可,为了方便理解,假设C端先发起,S端作为被动断开的一方;

在这里插入图片描述

其实我们三次握手的过程中的第二次,是将四次挥手中的中间两次合并优化了,那为啥TCP是四次挥手?其实这个说法有歧义,因为TCP多数情况下是4次挥手,但是也存在3次挥手的情况:

服务端有剩余数据需要发送–四次挥手(多数情况)

因为多数情况下,当c端主动与s端断开之后,s端不一定立即就与c端断开连接,可能还会有一些数据要发给c端,所以还会保持链接一段时间;

(当然TCP有保活机制,会通过设定时间间隔反复发送活性探测数据包,如果一段时间内没有响应或者一定的次数之后,就会断开这个链接释放资源)

服务端无剩余数据发送–捎带应答–四次变三次(少数情况)

在少数情况下,c端主动断开,s端恰巧也没啥要发的,也需要立即断开,那么TCP的捎带应答机制,就将四次挥手的中间两次进行合并,这时候四次挥手就变成了三次挥手;

四次挥手可能出现的问题

客户端或服务器均可主动发起挥手动作,调用close()即可,为了方便理解,假设C端先发起,S端作为被动断开的一方;

可能出现大量的TIME_WAIT

TIME_WAIT状态是C端收到了S端主动发送fin请求后,向S端发回了ACK确认断开报文之后出现的,需要保持2*MSL时间确保最后一个ACK报文能够到达S端,双方正常关闭; (设计成2*MSL的原因是确保响应ACK的传输时间和如果这个ACK丢失,S端重新发送FIN请求断开的时间)可见,msl一定是大于超时重传的时间的;

解决:

一台主机出现大量的TIME_WAIT证明这台主机上发起大量的主动关闭连接(常见于一些爬虫服务器)

这时候我们应该调整TIME_WAIT的等待时间(linux centos当时测试默认是60s),或者开启套接字地址重用选项

(否则这个端口号就被占用了,这个主机其他的服务就用不了这个端口号了…Bind Error)

可能出现大量的CLOSE_WAIT

CLOSE_WAIT是S端同意C端的fin请求之后进入的状态,等待上层程序进一步处理(比如发送剩余数据);

解决:

如果S端产生大量的CLOSE_WAIT,可能是内核断开连接后,S端忘记调用close,这就是我们程序员的疏忽了,写了个小bug;

相关内容

热门资讯

苹果还是安卓系统快,谁更胜一筹... 你有没有想过,手机里那个小小的操作系统,竟然能决定你的使用体验?今天,咱们就来聊聊这个热门话题:苹果...
安卓导航改苹果系统,无缝切换体... 你有没有想过,把安卓导航系统换成苹果系统,会是怎样的体验呢?想象你那熟悉的地图导航,突然间换了个“脸...
安卓导航如何进系统,系统生成与... 你有没有想过,你的安卓手机导航功能竟然可以深入到系统的核心呢?没错,今天就要来跟你聊聊这个神奇的话题...
电脑上面装安卓系统,全方位概述 你有没有想过,在你的电脑上装一个安卓系统?听起来是不是有点不可思议?但你知道吗,这可不是什么天方夜谭...
苹果刷安卓虚拟系统,刷机虚拟系... 你有没有想过,你的苹果手机竟然能装上安卓的虚拟系统?听起来是不是有点不可思议?别急,今天就来带你一探...
安卓 加密文件系统,安全存储与... 你知道吗?在安卓的世界里,有一个神秘的守护者,它就是安卓加密文件系统。今天,就让我带你一探究竟,揭开...
斑马系统怎么刷安卓,轻松实现系... 亲爱的读者,你是否曾想过给你的安卓设备来一次焕然一新的变身?没错,就是那种让你的手机瞬间变得与众不同...
怎样让安卓系统更新系统,轻松实... 亲爱的安卓用户们,你是否也和我一样,时不时地收到系统更新的提示,却总是犹豫不决,担心更新后手机会变慢...
如何看自己安卓系统,自我诊断与... 你有没有想过,你的安卓手机里那个默默无闻的系统,其实是个超级英雄呢?它每天都在为你保驾护航,从早晨闹...
安卓系统怎么拼写啊,Andro... 你问这个问题可真是戳中了我的技术盲区呢!安卓系统,这个名字听起来是不是很熟悉,就像你的手机里那个无所...
华为安卓系统被停用,挑战与转型... 你知道吗?最近科技圈可是炸开了锅!华为安卓系统被停用,这可不是一个小新闻哦。咱们得好好聊聊这个话题,...
安卓王者荣耀观战系统,沉浸式观... 亲爱的手机游戏爱好者们,你是否曾在王者荣耀的战场上,因为错过队友的精彩操作而扼腕叹息?或者,你是否渴...
怎么加安卓12系统,安卓12系... 你有没有发现,安卓系统每次更新都像是在给我们的小手机来一次华丽变身呢?这不,安卓12已经悄悄地来了,...
安卓系统阿联酋航空积分,便捷积... 你有没有想过,你的安卓手机里那些累积的积分,竟然可以在阿联酋航空的旅途中派上大用场?没错,就是那个带...
安卓系统录音文件位置,录音文件... 你有没有遇到过这种情况:手机里突然冒出了很多录音文件,但你就是找不到它们藏在哪里?别急,今天就来给你...
安卓灵动岛系统自带,智能交互新... 你知道吗?最近安卓手机界可是掀起了一股不小的风潮,那就是——安卓灵动岛系统自带功能!是不是听起来就让...
安卓支持ios系统下载,下载体... 你知道吗?最近在科技圈里可是掀起了一股小小的热潮呢!那就是安卓手机竟然支持iOS系统下载应用了!是不...
火山安卓加验证系统,安全与便捷... 你知道吗?在科技飞速发展的今天,手机安全可是个大问题。尤其是安卓系统,作为全球使用最广泛的操作系统之...
简化系统app安卓版,高效便捷... 你有没有发现,现在的生活节奏越来越快,信息爆炸的时代,我们每天都要处理海量的数据和信息。在这个时候,...
surfacepro2安卓系统... 你有没有想过,一台笔记本电脑竟然能像智能手机一样灵活多变?没错,今天我要跟你聊聊的就是这款神奇的设备...