TCP四次挥手的性能如何提升

image.png

三次握手是建立连接,四次挥手是关闭连接
TCP不允许连接处于半打开状态的时候单向传输数据。
TCP允许连接处于半关闭状态的时候单向传输数据。

本质上是四次握手,但是在三次握手的时候,服务器把ACKSYN一起发送给客户端,ack是用来打开客户端的发送通道,syn是用来打开服务器的发送通道,从而,原本是需要4次握手的,现在降为3次握手了。


四次挥手可以用netstat看到6种状态。
主动方:先关闭连接的一方
被动方:后关闭连接的一方

image.png


服务器常常是主动关闭连接的一方。
因为http是单向传输协议——

服务器接收完请求才能生成响应,发送完响应后会立刻关闭TCP连接(好处是及时地释放了资源,可以为更多用户服务)


image.png

四次挥手中只有2种报文——FINACK
谁发出FIN报文,表示它将不再发送任何数据,关闭这一方的传输通道。
ACK报文,通知对方:你方的发送通道已经关闭。
image.png


主动方的优化

关闭连接的方式有多种——

  1. 不安全的方式有:内核发送RST报文(属于不走四次挥手,强行关闭连接)来关闭。(如果报文延迟or重复传输,会导致数据错乱)
  2. 安全的方式:必须通过四次挥手,四次挥手是进程调用close或者shutdown函数发起的,它俩都会向对方发送FIN报文。
    image.png

主动方发送FIN报文后,如果一直收不到对方返回的ACK报文,就会重发(内核定时重发FIN报文)。当重发的次数达到设定的上界的时候,连接就会直接关闭掉。

image.png


所以说,在性能优化上,调低重发次数就可以了。
But如果遇到了恶意攻击,FIN报文就根本发不出去,因为TCP的2个特性——

  • TCP一定要保证报文是有序发送的
  • TCP有流量控制功能,如果接收方将接收窗口设置为0,发送方就不能发送数据了。



解决恶意攻击的方案是——调整孤儿连接的最大数量

---


shutdown函数和close函数的不同——
不能让孤儿连接持续太久

image.png


TIME_WAIT状态的保持(60s)是可以避免数据错乱的。因为被动方如果一直没收到ACK报文,会一直重发FIN报文。新连接可能会被这个重发的FIN报文错误关闭,所以需要保持一段时间的TIME_WAIT


保持的时间是60s的原因是这样的——
和2MSL有关系。

---


TIME_WAIT状态的存在也会消耗系统资源。因为TIME_WAIT状态的端口就无法供新连接使用。
所以为了节省资源,我们也要设定TIME_WAIT的连接数量。
但是如果并发很多,那么同时处于TIME_WAIT的连接数量也会变多,这个时候就需要增大TIME_WAIT的连接数量,从而减少不同的连接之间数据错乱的概率
但是内存有限,不能不断增加TW的数量,因此可以让新连接复用TW状态的端口。

image.png


被动方的优化

image.png

当被动方处于CLOSE_WAIT状态的时候,连接已经处于半关闭状态了,所以进程如果想要关闭连接,只能调用close函数。
被动方也要发送FIN报文,如果一直等不到ACK报文,内核就会一直重发FIN报文(这点和主动方重发是一样的策略)
因为被动方发送FIN报文是在调用close函数后,如果调用close函数的速度很快,那么被动方就可能同时发送ACK+FIN报文,这样四次握手就变成了三次握手(特殊情况)


还有一种很神奇的特例——连接双方同时关闭连接。
这种情况发生的时候,两方都会认为自己是主动方,所以都会进入FIN_WAIT1的状态,FIN报文的重发次数还是有参数可以控制。

因为双方发送FIN后,都在等待ACK,但是都等来了FIN报文,所以会有一个新的状态CLOSING,替代了原先的FIN_WAIT2。

那么这个时候,内核(双方)会回复ACK确认对方发送通道是否关闭,因为一直收不到ACK,所以CLOSING状态会在重发FIN报文的情况下关闭。

image.png

image.png


总结

  1. 我们谈到的优化,本质上是从主动方和连接方的连接状态来调整系统参数,从而可以在特定的情况下,及时的释放资源,节省资源。
  2. 主动方为了处理丢包的情况,可以在一个上限内重发FIN报文。
  3. 孤儿连接的数量太多也会占用系统资源,所以要给孤儿连接的数量设定一个上限,超过这个上限的时候,连接就会直接释放。
  4. 因为TIME_WAIT状态也会持续60s,为了防止TW占用太多的资源,也要设定TW连接的数量,超过的时候也会直接释放TW连接。除了直接释放,也可以通过设置参数让新连接复用TW状态的端口。
  5. 提升TCP的性能,需要观察连接状态,比如,出现大量的CLOSE_WAIT状态的连接的时候,应该从代码中找问题。
  6. 当被动方发送FIN报文后,在等ACK的时候,也要控制重发FIN报文的次数

实际应用

image.png
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,029评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,238评论 3 388
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,576评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,214评论 1 287
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,324评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,392评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,416评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,196评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,631评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,919评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,090评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,767评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,410评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,090评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,328评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,952评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,979评论 2 351