精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

字節一面:服務端掛了,客戶端的 TCP 連接還在嗎?

網絡 網絡管理
如果「服務端掛掉」指的是「服務端進程崩潰」,那么這個讀者猜的想法是對的,服務端的進程在發生崩潰的時候,內核會發送 FIN 報文,與客戶端進行四次揮手。

大家好,我是小林。

收到一位讀者的私信,說字節面試有這么一個問題:服務端掛了,客戶端的 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 保活機制)。

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

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

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

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

圖片

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

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

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

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

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

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

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

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

圖片

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

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 狀態。

責任編輯:武曉燕 來源: 小林coding
相關推薦

2009-08-21 15:36:41

服務端與客戶端

2009-08-21 15:54:40

服務端與客戶端

2009-08-21 16:14:52

服務端與客戶端通信

2011-09-09 09:44:23

WCF

2009-08-21 15:59:22

服務端與客戶端通信

2024-03-06 14:58:52

客戶端微服務架構

2010-11-19 14:22:04

oracle服務端

2023-03-06 08:01:56

MySQLCtrl + C

2010-03-18 17:47:07

Java 多客戶端通信

2022-12-02 13:49:41

2015-01-13 10:32:23

RestfulWeb框架

2023-04-03 08:13:05

MySQLCtrl + C

2018-12-18 10:47:37

2019-08-28 15:19:15

PythonTCP服務器

2022-06-14 15:07:04

IPC客戶端服務端

2021-06-11 06:54:34

Dubbo客戶端服務端

2021-10-19 08:58:48

Java 語言 Java 基礎

2018-12-20 08:50:53

TCPIP服務器

2010-06-09 14:39:58

2021-09-22 15:46:29

虛擬桌面瘦客戶端胖客戶端
點贊
收藏

51CTO技術棧公眾號

欧美一区 二区 三区| 欧美一级特黄aaaaaa大片在线观看 | 青青草原综合久久大伊人精品 | 国产激情在线观看视频| jizz在线观看| 国产不卡视频在线播放| 国产不卡视频在线| 卡通动漫亚洲综合| 网红女主播少妇精品视频| 欧美色区777第一页| 波多野结衣 作品| 国产视频二区在线观看| 国产精品中文字幕日韩精品| 欧美一级bbbbb性bbbb喷潮片| 色婷婷国产精品免| caoporn成人免费视频在线| 亚洲成人av资源| 超碰在线免费观看97| 深夜影院在线观看| 国产精品亚洲第一| 国产精品视频999| 色婷婷在线观看视频| 性xxxx欧美老肥妇牲乱| 亚洲精品一区二区在线| 国产大学生av| 日韩伦理一区二区| 色婷婷综合久久久中文字幕| 丰满的少妇愉情hd高清果冻传媒| 99re在线视频| 久久综合狠狠综合久久激情 | 牛牛精品成人免费视频| 91精品国产色综合久久不卡蜜臀| 国产男女激情视频| 欧美巨大丰满猛性社交| 一区二区三区免费网站| 正在播放91九色| av电影在线观看网址| 久久综合色天天久久综合图片| 91日韩久久| 国产精品玖玖玖| 琪琪一区二区三区| 国产成人短视频| 国产精品视频123| 亚洲麻豆视频| 97在线看免费观看视频在线观看| 强乱中文字幕av一区乱码| 99久久亚洲精品蜜臀| 这里只有精品在线播放| 国产真实乱人偷精品人妻| 自拍欧美一区| 亚洲片在线资源| 熟女高潮一区二区三区| 亚洲精品无吗| 亚洲女人天堂色在线7777| 久久精品老司机| 亚洲裸色大胆大尺寸艺术写真| 亚洲电影在线看| 国产草草浮力影院| 妖精一区二区三区精品视频| 精品香蕉一区二区三区| 久久精品国产亚洲AV熟女| 九九亚洲精品| 三级精品视频久久久久| 亚洲 欧美 变态 另类 综合| 一区二区三区国产精华| 美女扒开尿口让男人操亚洲视频网站| 2021亚洲天堂| 99成人精品| 日本乱人伦a精品| 瑟瑟视频在线免费观看| 久久福利资源站| 亚洲free性xxxx护士白浆| 亚洲第一页在线观看| 99视频精品全部免费在线| 精品一区日韩成人| 国产www.大片在线| 综合分类小说区另类春色亚洲小说欧美| 亚洲国产欧美在线成人app| 欧美一区视久久| 欧美久久久影院| 50路60路老熟妇啪啪| 成人看片毛片免费播放器| 欧美日韩一区不卡| 亚洲成人手机在线观看| 黄色欧美在线| 国产一区二区三区直播精品电影 | 国产精品久久久久久久久果冻传媒| 亚洲一区二区四区| 牛牛在线精品视频| 一本色道**综合亚洲精品蜜桃冫| 高清一区在线观看| 人人爱人人干婷婷丁香亚洲| 日韩av在线网页| 免费黄色在线网址| 影音先锋久久| 国产精品高潮粉嫩av| 国产99对白在线播放| 91在线观看一区二区| 亚洲欧洲精品在线观看| a级片在线免费| 欧美三级电影在线看| 亚洲少妇中文字幕| 成人在线免费视频观看| 自拍偷拍欧美专区| 91激情五月电影| 在线a免费观看| 亚洲激情播播| 欧美老肥婆性猛交视频| 无码人妻丰满熟妇区五十路| 国产乱码字幕精品高清av| 免费99视频| 羞羞的视频在线观看| 在线精品视频一区二区| 少妇极品熟妇人妻无码| 精品九九在线| 性欧美办公室18xxxxhd| 国产精品欧美亚洲| 2020国产成人综合网| 先锋影音男人资源| 精品欧美日韩精品| 亚洲国产福利在线| 一起操在线播放| 天堂va蜜桃一区二区三区漫画版| 97久久人人超碰caoprom欧美| 精品成人一区二区三区免费视频| 亚洲一区在线免费观看| 午夜国产一区二区三区| 欧美电影完整版在线观看| 欧美成人中文字幕在线| 亚洲一级片免费看| 久久久久成人黄色影片| 青青草成人免费在线视频| 成人乱码手机视频| 久久精品国产欧美激情| 五月激情丁香网| 久久先锋资源网| 欧美日韩成人免费视频| 盗摄牛牛av影视一区二区| 久久久国产精品x99av| 亚洲一线在线观看| 国产精品视频一区二区三区不卡| 国产裸体舞一区二区三区| 日韩av午夜| 91av视频在线观看| 天堂中文在线观看视频| 亚洲国产精品久久久久婷婷884| 日韩欧美色视频| 综合视频在线| 亚洲自拍小视频| av免费看在线| 日韩一区二区精品葵司在线 | 精品国产一区二区三区噜噜噜| 欧美亚洲激情在线| 欧美偷拍视频| 色综合欧美在线| 一色道久久88加勒比一| 日韩高清不卡一区| 亚洲a∨一区二区三区| 国产黄色精品| 久久久极品av| wwwav在线播放| 亚洲高清不卡在线| 日韩一级视频在线观看| 久久亚洲电影| 亚洲欧洲精品一区二区| 精品国产乱码久久久久久樱花| 欧美xxxx18国产| 欧美熟妇另类久久久久久不卡| 欧美日韩国产综合视频在线观看中文| 亚洲av成人无码一二三在线观看| 国产精品亚洲综合久久| 欧美日韩高清在线一区| 91精品店在线| 萌白酱国产一区二区| 理论片中文字幕| 色综合久久99| 国产小视频你懂的| 国产成人在线视频免费播放| 天堂…中文在线最新版在线| 精品国产aⅴ| 91久久久亚洲精品| av美女在线观看| 亚洲开心激情网| 中文字幕视频二区| 一区二区三区加勒比av| mm131美女视频| 久草热8精品视频在线观看| 日韩精品在线中文字幕| 国产精品探花在线观看| 亚洲xxxxx性| 亚洲人成在线网站| 美女精品视频一区| 欧美精品少妇| 欧美一区午夜视频在线观看| 久久国产精品波多野结衣| 久久九九影视网| 久久久久亚洲av无码专区首jn| 香蕉久久夜色精品| 色婷婷777777仙踪林| 欧美国产极品| 成人性教育视频在线观看| 日本蜜桃在线观看视频| 久久精品视频在线观看| 欧美69xxxxx| 欧美一区二区高清| 香蕉影院在线观看| 尤物在线观看一区| 亚洲av成人无码久久精品| 国产成人亚洲综合a∨婷婷图片| 男人的天堂99| 欧美日韩中文| 亚洲乱码一区二区三区| 欧美精品中文| 91久久精品一区二区别| 欧美日韩在线精品一区二区三区激情综合 | 蜜臀av粉嫩av懂色av| 蜜臀av性久久久久蜜臀aⅴ流畅| www.av蜜桃| 亚洲激情五月| 色乱码一区二区三在线看| 欧美电影在线观看免费| 91成人免费在线观看| 主播大秀视频在线观看一区二区| 97久久精品国产| 天堂8中文在线| 久久天天躁狠狠躁夜夜爽蜜月| 久热av在线| 日韩禁在线播放| 亚洲av无码国产综合专区| 欧美日韩国产色站一区二区三区| 国产一卡二卡三卡| 黄色一区二区在线观看| a在线视频播放观看免费观看| 国产欧美一区二区三区在线老狼| 男生裸体视频网站| 成年人午夜久久久| 91精品国产高清91久久久久久 | 午夜成人在线视频| 国产一级片免费观看| 一区二区三区在线影院| 日日噜噜夜夜狠狠久久波多野| 中文字幕欧美日韩一区| 欧美性受xxxx黑人| 欧美极品aⅴ影院| 在线观看国产精品一区| 国产午夜精品理论片a级大结局 | 国产欧美一区二区精品久导航 | 国产精品久久久毛片| 首页国产欧美日韩丝袜| 青青青在线播放| 久久经典综合| 欧美日韩亚洲一二三| 老**午夜毛片一区二区三区| 任你操这里只有精品| 日韩精品一区第一页| 日日噜噜夜夜狠狠| 久久99久久精品| 成人免费黄色av| 国模娜娜一区二区三区| 免费高清视频在线观看| 国产91富婆露脸刺激对白| 男女一区二区三区| 久久综合久久鬼色中文字| 亚洲一级中文字幕| 国产精品美女久久久久久2018 | 亚洲国产成人av网| 日韩精品一区二区在线播放| 欧美性猛交xxxx黑人| 午夜精品久久久久久久蜜桃| 欧美三级资源在线| 999国产精品视频免费| 精品国产免费一区二区三区香蕉 | 久久国产精品美女| 俄罗斯精品一区二区| 日韩成人av在线资源| 日韩影片在线播放| 亚洲国产老妈| 日本欧美黄色片| 美国十次了思思久久精品导航 | 99久久久免费精品国产一区二区 | √…a在线天堂一区| 精品一区在线观看视频| 精品国产31久久久久久| 中文字幕 自拍偷拍| 日韩欧美在线网站| 欧洲一区av| 久久综合久久八八| 偷拍自拍在线看| 国产综合福利在线| 理论片一区二区在线| 欧美一区二区福利| 欧美在线视屏| 欧美三级一级片| 久久99蜜桃精品| 国产精品无码电影| 国产精品久久二区二区| 豆国产97在线 | 亚洲| 在线观看一区二区视频| 精品人妻无码一区二区三区蜜桃一 | 性色av蜜臀av| 伊人久久五月天| 久草在线视频资源| 国产日韩专区在线| 神马午夜久久| 国风产精品一区二区| 日韩成人一级片| 亚洲天堂美女视频| 亚洲男人的天堂在线观看| 日本中文字幕第一页| 欧美sm极限捆绑bd| 在线观看黄色av| 欧美一级黄色网| 亚洲一区二区三区中文字幕在线观看 | 国产精品热久久| 亚洲情综合五月天| 91色在线看| 亚洲伊人久久大香线蕉av| 欧洲三级视频| 777久久久精品一区二区三区| 国产精品亚洲一区二区三区妖精| 欧美日韩生活片| 欧美日韩亚洲视频| 蜜桃在线一区二区| 久热精品视频在线| 伊人久久一区| 亚洲一区二区三区涩| 日欧美一区二区| 国产在线观看无码免费视频| 一区二区成人在线| av高清一区二区| 久久精品中文字幕电影| 欧美激情福利| 一级日韩一区在线观看| 日产国产高清一区二区三区| 波多野结衣一本| 精品福利在线看| 亚洲av片一区二区三区| 久久男人资源视频| 国产96在线亚洲| 你真棒插曲来救救我在线观看| 成人禁用看黄a在线| 久久亚洲成人av| 精品精品国产高清a毛片牛牛| 中日韩高清电影网| 114国产精品久久免费观看| 91精品国产91久久综合| 欧美美女一级片| 国产精品久久福利| 国产一区二区自拍视频| 久久精品影视伊人网| 成人噜噜噜噜| 成人黄色片免费| 成人午夜在线免费| xxxxxx国产| 日韩av影片在线观看| 中文字幕在线高清| 少妇精品久久久久久久久久| 日韩电影在线一区| 99精品中文字幕| 日韩一区二区免费在线观看| 乱插在线www| 久久久精彩视频| 日韩精品久久久久久| 一级免费黄色录像| 欧美一级精品大片| a级片免费在线观看| 久久综合一区二区三区| 日韩国产成人精品| frxxee中国xxx麻豆hd| 日韩一区二区免费视频| av漫画网站在线观看| 日韩啊v在线| 国产一区二区在线免费观看| 国产大片aaa| 亚洲性xxxx| avtt久久| 亚洲欧洲日产国码无码久久99| 日本一区二区视频在线观看| 国产又黄又大又爽| 久久久最新网址| 精品精品99| 精品国产一二区| 91成人看片片| 91国内在线| 另类欧美小说| 国产曰批免费观看久久久| 日韩精品成人一区| 国产一区二区三区在线观看视频 | 丁香激情五月少妇| 日韩三级视频在线看| 麻豆免费在线| 中国成人在线视频| av亚洲精华国产精华精华| 一区二区视频播放| 亚洲91av视频| 亚欧美无遮挡hd高清在线视频| 久久福利小视频| 欧美二区在线观看| 成人香蕉视频| 妞干网在线播放|