久久国产精品一区二区三区四区,久色婷婷小香蕉久久,国产日韩欧美在线播放不卡,另类av一区二区

全球微動態丨字節一面:服務端掛了,客戶端的 TCP 連接還在嗎?
來源:小林coding    時間:2022-09-05 15:47:21

大家好,我是小林。

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

如果「服務端掛掉」指的是「


【資料圖】

但是,如果「服務端掛掉」指的是「

如果客戶端會發送數據,由于服務端已經不存在,客戶端的數據報文會超時重傳,當重傳次數達到一定閾值后,會斷開 TCP 連接;如果客戶端一直不會發送數據,再看客戶端有沒有開啟 TCP keepalive 機制?

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

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

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

服務端進程崩潰,客戶端會發生什么?

TCP 的連接信息是由內核維護的,所以當服務端的進程崩潰后,內核需要回收該進程的所有 TCP 連接資源,于是內核會發送第一次揮手 FIN 報文,后續的揮手過程也都是在內核完成,并不需要進程的參與,所以即使服務端的進程退出了,還是能與客戶端完成 TCP四次揮手的過程。

我自己也做了實驗,使用 kill -9 命令來模擬進程崩潰的情況,發現在 kill 掉進程后,服務端會發送 FIN 報文,與客戶端進行四次揮手。

服務端主機宕機后,客戶端會發生什么?

當服務端的主機突然斷電了,這種情況就是屬于服務端主機宕機了。

當服務端的主機發生了宕機,是沒辦法和客戶端進行四次揮手的,所以在服務端主機發生宕機的那一時刻,客戶端是沒辦法立刻感知到服務端主機宕機了,只能在后續的數據交互中來感知服務端的連接已經不存在了。

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

服務端主機宕機后,客戶端會發送數據;服務端主機宕機后,客戶端一直不會發送數據;

服務端主機宕機后,如果客戶端會發送數據

在服務端主機宕機后,客戶端發送了數據報文,由于得不到響應,在等待一定時長后,客戶端就會觸發超時重傳機制,重傳未得到響應的數據報文。

當重傳次數達到達到一定閾值后,內核就會判定出該 TCP 連接有問題,然后通過 Socket 接口告訴應用程序該 TCP 連接出問題了,于是客戶端的 TCP 連接就會斷開。

那 TCP 的數據報文具體重傳幾次呢?

在 Linux 系統中,提供了一個叫 tcp_retries2 配置項,默認值是 15,如下圖:

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

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

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

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

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

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

最小 RTO 和最大 RTO 是在 Linux 內核中定義好了:

#define TCP_RTO_MAX ((unsigned)(120*HZ))#define TCP_RTO_MIN ((unsigned)(HZ/5))

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

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

服務端主機宕機后,如果客戶端一直不發數據

在服務端主機發送宕機后,如果客戶端一直不發送數據,那么還得看是否開啟了 TCP keepalive 機制 (TCP ?;顧C制)。

如果沒有開啟TCP keepalive 機制,在服務端主機發送宕機后,如果客戶端一直不發送數據,那么客戶端的 TCP 連接將一直保持存在,所以我們可以得知一個點,在沒有使用 TCP ?;顧C制,且雙方不傳輸數據的情況下,一方的 TCP 連接處在 ESTABLISHED 狀態時,并不代表另一方的 TCP 連接還一定是正常的。

而如果開啟了 TCP keepalive 機制,在服務端主機發送宕機后,即使客戶端一直不發送數據,在持續一段時間后,TCP 就會發送探測報文,探測服務端是否存活:

如果對端是正常工作的。當 TCP ?;畹奶綔y報文發送給對端, 對端會正常響應,這樣TCP ?;顣r間會被重置,等待下一個 TCP 保活時間的到來。如果對端主機崩潰,或對端由于其他原因導致報文不可達。當 TCP ?;畹奶綔y報文發送給對端后,石沉大海,沒有響應,連續幾次,達到?;钐綔y次數后,TCP 會報告該 TCP 連接已經死亡。

所以,TCP keepalive 機制可以在雙方沒有數據交互的情況,通過探測報文,來確定對方的 TCP 連接是否存活。

TCP keepalive 機制具體是怎么樣的?

TCP keepalive 機制機制的原理是這樣的:

定義一個時間段,在這個時間段內,如果沒有任何連接相關的活動,TCP ?;顧C制會開始作用,每隔一個時間間隔,發送一個探測報文,該探測報文包含的數據非常少,如果連續幾個探測報文都沒有得到響應,則認為當前的 TCP 連接已經死亡,系統內核將錯誤信息通知給上層應用程序。

在 Linux 內核可以有對應的參數可以設置?;顣r間、保活探測的次數、?;钐綔y的時間間隔,以下都為默認值:

net.ipv4.tcp_keepalive_time=7200net.ipv4.tcp_keepalive_intvl=75 net.ipv4.tcp_keepalive_probes=9

每個參數的意思,具體如下:

tcp_keepalive_time=7200:表示保活時間是 7200 秒(2小時),也就 2 小時內如果沒有任何連接相關的活動,則會啟動?;顧C制tcp_keepalive_intvl=75:表示每次檢測間隔 75 秒;tcp_keepalive_probes=9:表示檢測 9 次無響應,認為對方是不可達的,從而中斷本次的連接。

也就是說在 Linux 系統中,最少需要經過 2 小時 11 分 15 秒才可以發現一個「死亡」連接。

注意,應用程序如果想使用 TCP 保活機制,需要通過 socket 接口設置SO_KEEPALIVE選項才能夠生效,如果沒有設置,那么就無法使用 TCP ?;顧C制。

TCP keepalive 機制探測的時間也太長了吧?

對的,是有點長。

TCP keepalive 是TCP 層(內核態)實現的,它是給所有基于 TCP 傳輸協議的程序一個兜底的方案。

實際上,我們應用層可以自己實現一套探測機制,可以在較短的時間內,探測到對方是否存活。

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

總結

如果「服務端掛掉」指的是「服務端進程崩潰」,服務端的進程在發生崩潰的時候,內核會發送 FIN 報文,與客戶端進行四次揮手。

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

如果客戶端會發送數據,由于服務端已經不存在,客戶端的數據報文會超時重傳,當重傳總間隔時長達到一定閾值(內核會根據 tcp_retries2 設置的值計算出一個閾值)后,會斷開 TCP 連接;如果客戶端一直不會發送數據,再看客戶端有沒有開啟 TCP keepalive 機制?

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

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

關鍵詞: 發送數據 應用程序 一段時間 達到一定 已經不存在

上一篇:

下一篇:

X 關閉

X 關閉

久久国产精品一区二区三区四区,久色婷婷小香蕉久久,国产日韩欧美在线播放不卡,另类av一区二区
久久亚洲国产精品一区二区| 狠狠干狠狠久久| 国语自产精品视频在线看抢先版结局| 国产毛片一区二区| 午夜精品成人在线视频| 国产日产高清欧美一区二区三区| 欧美一区二区三区在线免费观看| 欧美在线视频一区| 久久人体大胆视频| 性欧美精品高清| 欧美在线观看视频| 中文av字幕一区| 新67194成人永久网站| 欧美一区二区三区免费观看| 国产精品国产福利国产秒拍| 国产精品男女猛烈高潮激情| 欧美午夜精品久久久久免费视| 久久精品国产亚洲高清剧情介绍| 韩国福利一区| 久久精品国产亚洲5555| 国产精品久久久一区二区| 先锋影院在线亚洲| 亚洲成人自拍视频| 亚洲欧美中文日韩v在线观看| 宅男在线国产精品| 欧美亚洲免费高清在线观看| 美女国内精品自产拍在线播放| 亚洲欧美激情视频| 亚洲欧美综合精品久久成人| 欧美日韩国产综合新一区| 在线免费高清一区二区三区| 亚洲欧美激情四射在线日| 黑丝一区二区| 亚洲国产精品一区二区第四页av| 国产欧美婷婷中文| 欧美日韩在线观看视频| 亚洲视频在线二区| 亚洲视频一区在线观看| 亚洲视频国产视频| 在线播放中文一区| 亚洲欧美日韩成人高清在线一区| 午夜精品福利在线观看| 国产在线视频欧美一区二区三区| 亚洲第一黄色网| 男同欧美伦乱| 亚洲男同1069视频| 一区二区在线观看视频| 狠狠色综合网| 国产丝袜美腿一区二区三区| 在线看国产一区| 欧美二区乱c少妇| 国产一区二区三区直播精品电影| 国产精品久久波多野结衣| 免费在线成人| 亚洲国产精品精华液网站| 午夜视频在线观看一区二区三区| 欧美成人情趣视频| 亚洲欧美日本国产专区一区| 久久亚洲国产精品日日av夜夜| 欧美在线一级视频| 欧美三级日韩三级国产三级| 日韩午夜黄色| 国产一区二区看久久| 亚洲激情一区二区| 欧美大片一区二区| 国产嫩草一区二区三区在线观看| 中日韩视频在线观看| 午夜精品久久99蜜桃的功能介绍| 国产精品乱看| 日韩网站在线看片你懂的| 亚洲永久精品大片| 亚洲国产精品成人一区二区| 欧美涩涩网站| 亚洲欧美日韩国产精品| 国产日韩成人精品| 欧美日韩一区二区三区在线观看免| 亚洲破处大片| 亚洲天堂免费观看| 亚洲欧美偷拍卡通变态| 国产精品av久久久久久麻豆网| 国产人久久人人人人爽| 亚洲国产精品尤物yw在线观看| 欧美1区3d| 久久精品视频免费观看| 亚洲欧美激情精品一区二区| 欧美日韩在线三区| 亚洲伊人久久综合| 亚洲第一偷拍| 欧美有码在线观看视频| 欧美日韩精品免费观看视频| 欧美极品aⅴ影院| 久久蜜桃av一区精品变态类天堂| 激情欧美日韩一区| 亚洲精品国久久99热| 欧美精品www在线观看| 性欧美大战久久久久久久久| 欧美劲爆第一页| 在线精品视频一区二区三四| 国产香蕉97碰碰久久人人| 亚洲激情在线播放| 国产亚洲欧美日韩精品| 久久久成人精品| 欧美中文字幕久久| 最新国产の精品合集bt伙计| 国产一区二区三区日韩| 久久综合图片| 欧美成人日韩| 免费在线看一区| 亚洲精品自在久久| 亚洲男女自偷自拍| 亚洲网站在线观看| 久久er精品视频| 亚洲国产精品日韩| 一二三四社区欧美黄| 一区二区三区国产在线| 国产精品xvideos88| 久久激情视频免费观看| 国产女人精品视频| 日韩亚洲视频在线| 国产精品久久久久久久久借妻| 黄色日韩在线| 国产精品系列在线| 欧美日韩一级视频| 国产三级欧美三级日产三级99| 国产视频一区三区| 亚洲欧美日本精品| 国内综合精品午夜久久资源| 欧美三级在线播放| 久久一区二区视频| 在线欧美三区| 欧美日本国产一区| 久久精品2019中文字幕| 欧美无乱码久久久免费午夜一区| 久久人体大胆视频| 欧美一区亚洲二区| 精品91在线| 亚洲综合首页| 欧美韩日一区二区三区| 欧美一区二区三区视频在线| 午夜精品在线看| 亚洲国产一区二区在线| 韩国av一区| 欧美激情精品久久久久久久变态| 欧美日韩在线播| 久久久久久91香蕉国产| 国产精品海角社区在线观看| 国产欧美精品va在线观看| 久久在线精品| 亚洲国产精品va| 国产精品高清在线| 欧美激情一区二区三区全黄| 欧美中文字幕在线播放| 老司机精品福利视频| 在线不卡中文字幕| 欧美日韩在线一区二区三区| 黄色成人在线| 亚洲精品美女久久7777777| 国产精品人人爽人人做我的可爱| 国产亚洲精品久| 欧美亚洲成人免费| 国产在线视频欧美| 亚洲视频www| 亚洲精品免费在线| 国产欧美欧洲在线观看| 国产欧美日韩高清| 国产精品v日韩精品v欧美精品网站| 午夜一区二区三区在线观看| 国产一区二区三区成人欧美日韩在线观看| 亚洲影视中文字幕| 久久蜜桃香蕉精品一区二区三区| 国产欧美在线播放| 黄色亚洲网站| 亚洲国产精品va在线观看黑人| 亚洲欧洲精品一区二区三区不卡| 午夜视频在线观看一区二区三区| 欧美3dxxxxhd| 午夜在线视频一区二区区别| 久久综合九色综合欧美狠狠| 亚洲欧美怡红院| 欧美性久久久| 国产一区二区看久久| 国产免费成人在线视频| 欧美日韩在线免费| 亚洲欧美国产高清va在线播| 欧美高清视频一区二区| 夜夜精品视频一区二区| 国产女人水真多18毛片18精品视频| 夜夜嗨av一区二区三区四季av| 狠狠色综合色综合网络| 国产亚洲欧美一级| 欧美精品激情在线| 日韩视频在线观看免费| 国产欧美日本| 国产日本欧美视频| 亚洲欧洲精品一区二区三区| 亚洲韩国一区二区三区| 欧美一区二区黄| 亚洲欧美日韩视频一区| 欧美另类一区| 久久久久久亚洲精品杨幂换脸|