国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区

掃一掃
關(guān)注微信公眾號

字節(jié)一面:服務(wù)端掛了,客戶端的 TCP 連接還在嗎?
2022-09-07   轉(zhuǎn)載

大家好,我是小林。

收到一位讀者的私信,說字節(jié)面試有這么一個問題:服務(wù)端掛了,客戶端的 TCP 連接會發(fā)生什么?

如果「服務(wù)端掛掉」指的是「

但是,如果「服務(wù)端掛掉」指的是「

  • 如果客戶端會發(fā)送數(shù)據(jù),由于服務(wù)端已經(jīng)不存在,客戶端的數(shù)據(jù)報(bào)文會超時重傳,當(dāng)重傳次數(shù)達(dá)到一定閾值后,會斷開 TCP 連接;
  • 如果客戶端一直不會發(fā)送數(shù)據(jù),再看客戶端有沒有開啟 TCP keepalive 機(jī)制?

如果有開啟,客戶端在一段時間后,檢測到服務(wù)端的 TCP 連接已經(jīng)不存在,則會斷開自身的 TCP 連接;

如果沒有開啟,客戶端的 TCP 連接會一直存在,并不會斷開。

上面屬于精簡回答了,下面我們詳細(xì)聊聊。

服務(wù)端進(jìn)程崩潰,客戶端會發(fā)生什么?

TCP 的連接信息是由內(nèi)核維護(hù)的,所以當(dāng)服務(wù)端的進(jìn)程崩潰后,內(nèi)核需要回收該進(jìn)程的所有 TCP 連接資源,于是內(nèi)核會發(fā)送第一次揮手 FIN 報(bào)文,后續(xù)的揮手過程也都是在內(nèi)核完成,并不需要進(jìn)程的參與,所以即使服務(wù)端的進(jìn)程退出了,還是能與客戶端完成 TCP四次揮手的過程。

我自己也做了實(shí)驗(yàn),使用 kill -9 命令來模擬進(jìn)程崩潰的情況,發(fā)現(xiàn)在 kill 掉進(jìn)程后,服務(wù)端會發(fā)送 FIN 報(bào)文,與客戶端進(jìn)行四次揮手。

服務(wù)端主機(jī)宕機(jī)后,客戶端會發(fā)生什么?

當(dāng)服務(wù)端的主機(jī)突然斷電了,這種情況就是屬于服務(wù)端主機(jī)宕機(jī)了。

當(dāng)服務(wù)端的主機(jī)發(fā)生了宕機(jī),是沒辦法和客戶端進(jìn)行四次揮手的,所以在服務(wù)端主機(jī)發(fā)生宕機(jī)的那一時刻,客戶端是沒辦法立刻感知到服務(wù)端主機(jī)宕機(jī)了,只能在后續(xù)的數(shù)據(jù)交互中來感知服務(wù)端的連接已經(jīng)不存在了。

因此,我們要分兩種情況來討論:

  • 服務(wù)端主機(jī)宕機(jī)后,客戶端會發(fā)送數(shù)據(jù);
  • 服務(wù)端主機(jī)宕機(jī)后,客戶端一直不會發(fā)送數(shù)據(jù);

服務(wù)端主機(jī)宕機(jī)后,如果客戶端會發(fā)送數(shù)據(jù)

在服務(wù)端主機(jī)宕機(jī)后,客戶端發(fā)送了數(shù)據(jù)報(bào)文,由于得不到響應(yīng),在等待一定時長后,客戶端就會觸發(fā)超時重傳機(jī)制,重傳未得到響應(yīng)的數(shù)據(jù)報(bào)文。

當(dāng)重傳次數(shù)達(dá)到達(dá)到一定閾值后,內(nèi)核就會判定出該 TCP 連接有問題,然后通過 Socket 接口告訴應(yīng)用程序該 TCP 連接出問題了,于是客戶端的 TCP 連接就會斷開。

 

那 TCP 的數(shù)據(jù)報(bào)文具體重傳幾次呢?

 

在 Linux 系統(tǒng)中,提供了一個叫 tcp_retries2 配置項(xiàng),默認(rèn)值是 15,如下圖:

這個內(nèi)核參數(shù)是控制,在 TCP 連接建立的情況下,超時重傳的最大次數(shù)。

不過 tcp_retries2 設(shè)置了 15 次,并不代表 TCP 超時重傳了 15 次才會通知應(yīng)用程序終止該 TCP 連接,內(nèi)核會根據(jù) tcp_retries2 設(shè)置的值,計(jì)算出一個 timeout(如果 tcp_retries2 =15,那么計(jì)算得到的 timeout = 924600 ms),如果重傳間隔超過這個 timeout,則認(rèn)為超過了閾值,就會停止重傳,然后就會斷開 TCP 連接。

在發(fā)生超時重傳的過程中,每一輪的超時時間(RTO)都是倍數(shù)增長的,比如如果第一輪 RTO 是 200 毫秒,那么第二輪 RTO 是 400 毫秒,第三輪 RTO 是 800 毫秒,以此類推。

而 RTO 是基于 RTT(一個包的往返時間) 來計(jì)算的,如果 RTT 較大,那么計(jì)算出來的 RTO 就越大,那么經(jīng)過幾輪重傳后,很快就達(dá)到了上面的 timeout 值了。

舉個例子,如果 tcp_retries2 =15,那么計(jì)算得到的 timeout = 924600 ms,如果重傳總間隔時長達(dá)到了 timeout 就會停止重傳,然后就會斷開 TCP 連接:

  • 如果 RTT 比較小,那么 RTO 初始值就約等于下限 200ms,也就是第一輪的超時時間是 200 毫秒,由于 timeout 總時長是 924600 ms,表現(xiàn)出來的現(xiàn)象剛好就是重傳了 15 次,超過了 timeout 值,從而斷開 TCP 連接
  • 如果 RTT 比較大,假設(shè) RTO 初始值計(jì)算得到的是 1000 ms,也就是第一輪的超時時間是 1 秒,那么根本不需要重傳 15 次,重傳總間隔就會超過 924600 ms。

最小 RTO 和最大 RTO 是在 Linux 內(nèi)核中定義好了:

 
#define TCP_RTO_MAX ((unsigned)(120*HZ))
#define TCP_RTO_MIN ((unsigned)(HZ/5))
  • 1.
  • 2.

Linux 2.6+ 使用 1000 毫秒的 HZ,因此TCP_RTO_MIN?約為 200 毫秒,TCP_RTO_MAX約為 120 秒。

如果tcp_retries?設(shè)置為15,且  RTT 比較小,那么 RTO 初始值就約等于下限 200ms,這意味著它需要 924.6 秒才能將斷開的 TCP 連接通知給上層(即應(yīng)用程序),每一輪的 RTO 增長關(guān)系如下表格:

服務(wù)端主機(jī)宕機(jī)后,如果客戶端一直不發(fā)數(shù)據(jù)

在服務(wù)端主機(jī)發(fā)送宕機(jī)后,如果客戶端一直不發(fā)送數(shù)據(jù),那么還得看是否開啟了 TCP keepalive 機(jī)制 (TCP 保活機(jī)制)。

如果沒有開啟 TCP keepalive 機(jī)制,在服務(wù)端主機(jī)發(fā)送宕機(jī)后,如果客戶端一直不發(fā)送數(shù)據(jù),那么客戶端的 TCP 連接將一直保持存在,所以我們可以得知一個點(diǎn),在沒有使用 TCP 保活機(jī)制,且雙方不傳輸數(shù)據(jù)的情況下,一方的 TCP 連接處在 ESTABLISHED 狀態(tài)時,并不代表另一方的 TCP 連接還一定是正常的。

而如果開啟了 TCP keepalive 機(jī)制,在服務(wù)端主機(jī)發(fā)送宕機(jī)后,即使客戶端一直不發(fā)送數(shù)據(jù),在持續(xù)一段時間后,TCP 就會發(fā)送探測報(bào)文,探測服務(wù)端是否存活:

  • 如果對端是正常工作的。當(dāng) TCP 保活的探測報(bào)文發(fā)送給對端, 對端會正常響應(yīng),這樣TCP 保活時間會被重置,等待下一個 TCP 保活時間的到來。
  • 如果對端主機(jī)崩潰,或?qū)Χ擞捎谄渌驅(qū)е聢?bào)文不可達(dá)。當(dāng) TCP 保活的探測報(bào)文發(fā)送給對端后,石沉大海,沒有響應(yīng),連續(xù)幾次,達(dá)到保活探測次數(shù)后,TCP 會報(bào)告該 TCP 連接已經(jīng)死亡。

所以,TCP keepalive 機(jī)制可以在雙方?jīng)]有數(shù)據(jù)交互的情況,通過探測報(bào)文,來確定對方的 TCP 連接是否存活。

 

TCP keepalive 機(jī)制具體是怎么樣的?

 

TCP keepalive 機(jī)制機(jī)制的原理是這樣的:

定義一個時間段,在這個時間段內(nèi),如果沒有任何連接相關(guān)的活動,TCP 保活機(jī)制會開始作用,每隔一個時間間隔,發(fā)送一個探測報(bào)文,該探測報(bào)文包含的數(shù)據(jù)非常少,如果連續(xù)幾個探測報(bào)文都沒有得到響應(yīng),則認(rèn)為當(dāng)前的 TCP 連接已經(jīng)死亡,系統(tǒng)內(nèi)核將錯誤信息通知給上層應(yīng)用程序。

在 Linux 內(nèi)核可以有對應(yīng)的參數(shù)可以設(shè)置保活時間、保活探測的次數(shù)、保活探測的時間間隔,以下都為默認(rèn)值:

 
net.ipv4.tcp_keepalive_time=7200
net.ipv4.tcp_keepalive_intvl=75  
net.ipv4.tcp_keepalive_probes=9
  • 1.
  • 2.
  • 3.

每個參數(shù)的意思,具體如下:

  • tcp_keepalive_time=7200:表示保活時間是 7200 秒(2小時),也就 2 小時內(nèi)如果沒有任何連接相關(guān)的活動,則會啟動保活機(jī)制
  • tcp_keepalive_intvl=75:表示每次檢測間隔 75 秒;
  • tcp_keepalive_probes=9:表示檢測 9 次無響應(yīng),認(rèn)為對方是不可達(dá)的,從而中斷本次的連接。

也就是說在 Linux 系統(tǒng)中,最少需要經(jīng)過 2 小時 11 分 15 秒才可以發(fā)現(xiàn)一個「死亡」連接。

注意,應(yīng)用程序如果想使用 TCP 保活機(jī)制,需要通過 socket 接口設(shè)置 SO_KEEPALIVE 選項(xiàng)才能夠生效,如果沒有設(shè)置,那么就無法使用 TCP 保活機(jī)制。

 

TCP keepalive 機(jī)制探測的時間也太長了吧?

 

對的,是有點(diǎn)長。

TCP keepalive 是 TCP 層(內(nèi)核態(tài)) 實(shí)現(xiàn)的,它是給所有基于 TCP 傳輸協(xié)議的程序一個兜底的方案。

實(shí)際上,我們應(yīng)用層可以自己實(shí)現(xiàn)一套探測機(jī)制,可以在較短的時間內(nèi),探測到對方是否存活。

比如,web 服務(wù)軟件一般都會提供 keepalive_timeout 參數(shù),用來指定 HTTP 長連接的超時時間。如果設(shè)置了 HTTP 長連接的超時時間是 60 秒,web 服務(wù)軟件就會啟動一個定時器,如果客戶端在完后一個 HTTP 請求后,在 60 秒內(nèi)都沒有再發(fā)起新的請求,定時器的時間一到,就會觸發(fā)回調(diào)函數(shù)來釋放該連接。

圖片

總結(jié)

如果「服務(wù)端掛掉」指的是「服務(wù)端進(jìn)程崩潰」,服務(wù)端的進(jìn)程在發(fā)生崩潰的時候,內(nèi)核會發(fā)送 FIN 報(bào)文,與客戶端進(jìn)行四次揮手。

但是,如果「服務(wù)端掛掉」指的是「服務(wù)端主機(jī)宕機(jī)」,那么是不會發(fā)生四次揮手的,具體后續(xù)會發(fā)生什么?還要看客戶端會不會發(fā)送數(shù)據(jù)?

  • 如果客戶端會發(fā)送數(shù)據(jù),由于服務(wù)端已經(jīng)不存在,客戶端的數(shù)據(jù)報(bào)文會超時重傳,當(dāng)重傳總間隔時長達(dá)到一定閾值(內(nèi)核會根據(jù) tcp_retries2 設(shè)置的值計(jì)算出一個閾值)后,會斷開 TCP 連接;
  • 如果客戶端一直不會發(fā)送數(shù)據(jù),再看客戶端有沒有開啟 TCP keepalive 機(jī)制?

如果有開啟,客戶端在一段時間沒有進(jìn)行數(shù)據(jù)交互時,會觸發(fā) TCP keepalive 機(jī)制,探測對方是否存在,如果探測到對方已經(jīng)消亡,則會斷開自身的 TCP 連接;

如果沒有開啟,客戶端的 TCP 連接會一直存在,并且一直保持在 ESTABLISHED 狀態(tài)。

熱詞搜索:

上一篇:淺談基于設(shè)備指紋的網(wǎng)絡(luò)安全機(jī)器防御系統(tǒng)
下一篇:最后一頁

分享到: 收藏
国产一级一区二区_segui88久久综合9999_97久久夜色精品国产_欧美色网一区二区
一本色道久久加勒比88综合| 亚洲精品一区久久久久久| 欧美日韩蜜桃| 国产精品福利在线观看| 国内精品久久久久久影视8 | 亚洲精品久久7777| 国产精品久久夜| 亚洲风情亚aⅴ在线发布| 亚洲欧美国产va在线影院| 久久久久久999| 欧美体内she精视频| 亚洲精品1区| 久久深夜福利| 国产视频丨精品|在线观看| 在线一区二区三区四区五区| 久久精品一区蜜桃臀影院| 国产精品亚洲精品| 亚洲天堂黄色| 欧美图区在线视频| 99热在这里有精品免费| 欧美88av| 国产丝袜一区二区| 亚洲男人av电影| 欧美性一区二区| 日韩视频一区二区| 欧美成人亚洲成人日韩成人| 伊人婷婷欧美激情| 久久夜色撩人精品| 影音先锋久久| 欧美大片免费观看| 亚洲午夜激情在线| 国产日本欧美在线观看| 欧美在线日韩| 黄色日韩网站| 欧美日韩黄色一区二区| 亚洲视频在线免费观看| 国产精品一区二区在线观看网站 | 欧美激情亚洲综合一区| 亚洲电影免费观看高清完整版在线观看| 久久精品亚洲精品| 免费观看欧美在线视频的网站| 国产女人aaa级久久久级| 亚洲美女淫视频| 欧美日韩国产成人在线91| 亚洲国产精品成人一区二区| 欧美成人激情在线| 国产欧美大片| 欧美亚洲一区| 亚洲三级电影在线观看| 免费黄网站欧美| 一区免费视频| 欧美日韩在线一区二区| 91久久国产综合久久蜜月精品 | 亚洲精品永久免费精品| 欧美日韩综合在线免费观看| 亚洲激情网站| 久久久久久久一区二区三区| 99re在线精品| 欧美久久综合| 日韩一级二级三级| 国产一区二区三区四区老人| 午夜在线一区| 国产视频丨精品|在线观看| 欧美精品观看| 亚洲精品小视频在线观看| 美女91精品| 亚洲综合精品一区二区| 国产精品久久激情| 亚洲欧美综合v| 久久久久久久久蜜桃| 国自产拍偷拍福利精品免费一| 欧美亚洲一级| 欧美福利一区二区三区| 性欧美xxxx大乳国产app| 国产精品人人做人人爽| 亚洲免费一级电影| av成人毛片| 国产精品高潮呻吟久久av无限 | 性伦欧美刺激片在线观看| 欧美系列精品| 亚洲欧美日韩一区二区三区在线观看| 国产精品网站在线| 亚洲无毛电影| 国产午夜亚洲精品羞羞网站| 久久久久久久综合狠狠综合| 欧美日韩一本到| 久久乐国产精品| 亚洲盗摄视频| 欧美日韩免费高清| 国产视频欧美| 裸体一区二区三区| 亚洲高清激情| 中文精品一区二区三区| 亚洲黄色视屏| 国产精品久久久久久久免费软件| 国产一区二区精品| 国产欧美日韩亚洲一区二区三区 | 狠狠色狠色综合曰曰| 久久九九99| 久久精品国产亚洲高清剧情介绍| 狠狠狠色丁香婷婷综合久久五月| 久久精品一区二区| 欧美性大战xxxxx久久久| 欧美日韩另类综合| 性欧美video另类hd性玩具| 国产精品久久久久aaaa| 国产精品色网| 久久婷婷亚洲| 中文亚洲免费| 亚洲欧美电影院| 亚洲高清三级视频| 欧美高清视频一区| 欧美99久久| 亚洲欧美日韩另类| 国产日韩欧美一二三区| 国内精品久久久久影院色| 欧美激情亚洲自拍| 日韩视频一区二区三区在线播放 | 欧美有码在线观看视频| 极品中文字幕一区| 亚洲黄网站黄| 欧美日韩mv| 久久久久久**毛片大全| 国产精品自拍三区| 蜜乳av另类精品一区二区| 亚洲一区三区电影在线观看| 国产精品红桃| 国产亚洲一区在线| 国产精品欧美一区喷水| 性做久久久久久久久| 亚洲高清资源| 国产日韩欧美一区二区三区在线观看 | 一区二区成人精品 | 欧美日韩国产系列| 亚洲免费在线| 久久综合久久综合久久| 亚洲欧美日韩国产综合| 99在线热播精品免费| 香蕉久久夜色精品国产| 亚洲视频综合| 99亚洲视频| 久久久精品久久久久| 亚洲欧美日韩精品久久久| 99精品免费视频| 久久福利毛片| 亚洲婷婷在线| 一区二区欧美激情| 久久国产免费看| 午夜电影亚洲| 亚洲少妇自拍| 理论片一区二区在线| 先锋影音国产精品| 欧美香蕉视频| 国产午夜精品福利 | 午夜视频在线观看一区二区三区 | 亚洲第一成人在线| 国产一区二区精品久久99| 日韩视频在线你懂得| 亚洲激情在线视频| 亚洲黄色尤物视频| 欧美在线视频日韩| 欧美亚洲免费高清在线观看| 在线看无码的免费网站| 性欧美8khd高清极品| 欧美一区免费视频| 国产精品成av人在线视午夜片| 欧美日韩综合不卡| 欧美日韩一区二区三区在线 | 一区二区三区免费在线观看| 亚洲欧洲三级| 国产亚洲午夜| 亚洲欧美日韩精品久久久| 亚洲永久网站| 在线亚洲高清视频| 午夜精品久久久久久久久久久久| 亚洲免费在线看| 欧美日韩国产首页| 国产精品久久久| 国产精品国产三级国产a| 亚洲国产日韩一级| 99re在线精品| 日韩一级片网址| 久久精品色图| 美日韩在线观看| 欧美日本一区二区三区| 亚洲国产aⅴ天堂久久| 亚洲国产婷婷香蕉久久久久久99| 亚洲高清一区二区三区| 久久蜜桃资源一区二区老牛| 美女视频黄a大片欧美| 欧美激情黄色片| 亚洲欧洲日产国码二区| 亚洲视频欧美在线| 日韩视频中午一区| 欧美大片在线影院| 欧美日韩p片| 亚洲伦伦在线| 美女爽到呻吟久久久久| 欧美视频二区| 亚洲一二区在线|