如何提升TCP三次握手的性能?(涉及半連接宰缤、全連接)

TCP 三次握手就三個(gè)狀態(tài) :syn_sent挽懦、syn_rcv纺阔、established

一、客戶端的優(yōu)化

三次握手建立連接的首要目的是同步序列號(hào)。只有同步了序列號(hào)才有可靠的傳輸客年,TCP 協(xié)議的許多特性都是依賴序列號(hào)實(shí)現(xiàn)的,比如流量控制叮贩、消息丟失后的重發(fā)等等

客戶端在等待服務(wù)器回復(fù)的 ACK 報(bào)文几于。正常情況下,服務(wù)器會(huì)在幾毫秒內(nèi)返回 ACK筹陵,但如果客戶端遲遲沒(méi)有收到 ACK 會(huì)怎么樣呢刽锤?客戶端會(huì)重發(fā) SYN,重試的次數(shù)由tcp_syn_retries 參數(shù)控制朦佩,默認(rèn)是 6 次并思。

優(yōu)化:可以適當(dāng)調(diào)低重試次數(shù),盡快把錯(cuò)誤暴露給應(yīng)用程序语稠。

二宋彼、服務(wù)器端的優(yōu)化

在SYN_RCV(RCV 是 received 的縮寫(xiě))狀態(tài)下,服務(wù)器必須建立一個(gè) SYN 半連接隊(duì)列來(lái)維護(hù)未完成的握手信息仙畦,當(dāng)這個(gè)隊(duì)列溢出后输涕,服務(wù)器將無(wú)法再建立新連接。


新連接建立失敗的原因有很多议泵,怎樣獲得由于隊(duì)列已滿而引發(fā)的失敗次數(shù)呢占贫?netstat -s 命令給出的統(tǒng)計(jì)結(jié)果中可以得到隊(duì)列溢出導(dǎo)致 SYN 被丟棄的個(gè)數(shù)

優(yōu)化:調(diào)大 SYN 半連接隊(duì)列

如果 SYN 半連接隊(duì)列已滿先口,只能丟棄連接嗎型奥?并不是這樣,開(kāi)啟 syncookies 功能就可以在不使用 SYN 隊(duì)列的情況下成功建立連接碉京。syncookies 是這么做的:服務(wù)器根據(jù)當(dāng)前狀態(tài)計(jì)算出一個(gè)值厢汹,放在己方發(fā)出的 SYN+ACK 報(bào)文中發(fā)出,當(dāng)客戶端返回 ACK 報(bào)文時(shí)谐宙,取出該值驗(yàn)證烫葬,如果合法,就認(rèn)為連接建立成功

由于 syncookie 僅用于應(yīng)對(duì)SYN 泛洪攻擊(攻擊者惡意構(gòu)造大量的 SYN 報(bào)文發(fā)送給服務(wù)器搭综,造成 SYN 半連接隊(duì)列溢出垢箕,導(dǎo)致正常客戶端的連接無(wú)法建立)兑巾,這種方式建立的連接条获,許多 TCP 特性都無(wú)法使用。所以蒋歌,應(yīng)當(dāng)把 tcp_syncookies 設(shè)置為 1帅掘,僅在隊(duì)列滿時(shí)再啟用。

服務(wù)器收到 ACK 后連接建立成功堂油,此時(shí)修档,內(nèi)核會(huì)把連接從 SYN 半連接隊(duì)列中移出,再移入 accept 隊(duì)列府框,等待進(jìn)程調(diào)用 accept 函數(shù)時(shí)把連接取出來(lái)吱窝。如果進(jìn)程不能及時(shí)地調(diào)用accept 函數(shù),就會(huì)造成 accept 隊(duì)列溢出寓免,最終導(dǎo)致建立好的 TCP 連接被丟棄癣诱。

TFO 技術(shù)繞過(guò)三次握手,使得 HTTP 請(qǐng)求減少了 1 個(gè) RTT 的時(shí)間袜香。Linux 下可以通過(guò)tcp_fastopen 參數(shù)開(kāi)啟該功能撕予。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蜈首,隨后出現(xiàn)的幾起案子实抡,更是在濱河造成了極大的恐慌,老刑警劉巖欢策,帶你破解...
    沈念sama閱讀 216,544評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件吆寨,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡踩寇,警方通過(guò)查閱死者的電腦和手機(jī)啄清,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)俺孙,“玉大人辣卒,你說(shuō)我怎么就攤上這事【﹂” “怎么了荣茫?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,764評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)场靴。 經(jīng)常有香客問(wèn)我啡莉,道長(zhǎng)港准,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,193評(píng)論 1 292
  • 正文 為了忘掉前任咧欣,我火速辦了婚禮浅缸,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘该押。我一直安慰自己疗杉,他們只是感情好阵谚,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布蚕礼。 她就那樣靜靜地躺著,像睡著了一般梢什。 火紅的嫁衣襯著肌膚如雪奠蹬。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,182評(píng)論 1 299
  • 那天嗡午,我揣著相機(jī)與錄音囤躁,去河邊找鬼。 笑死荔睹,一個(gè)胖子當(dāng)著我的面吹牛狸演,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播僻他,決...
    沈念sama閱讀 40,063評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼宵距,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了吨拗?” 一聲冷哼從身側(cè)響起满哪,我...
    開(kāi)封第一講書(shū)人閱讀 38,917評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎劝篷,沒(méi)想到半個(gè)月后哨鸭,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,329評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡娇妓,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評(píng)論 2 332
  • 正文 我和宋清朗相戀三年像鸡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片哈恰。...
    茶點(diǎn)故事閱讀 39,722評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡只估,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出蕊蝗,到底是詐尸還是另有隱情仅乓,我是刑警寧澤,帶...
    沈念sama閱讀 35,425評(píng)論 5 343
  • 正文 年R本政府宣布蓬戚,位于F島的核電站夸楣,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜豫喧,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評(píng)論 3 326
  • 文/蒙蒙 一石洗、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧紧显,春花似錦讲衫、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,671評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至篙程,卻和暖如春枷畏,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背虱饿。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,825評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工拥诡, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人氮发。 一個(gè)月前我還...
    沈念sama閱讀 47,729評(píng)論 2 368
  • 正文 我出身青樓渴肉,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親爽冕。 傳聞我的和親對(duì)象是個(gè)殘疾皇子仇祭,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容