青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

牽著老婆滿街逛

嚴以律己,寬以待人. 三思而后行.
GMail/GTalk: yanglinbo#google.com;
MSN/Email: tx7do#yahoo.com.cn;
QQ: 3 0 3 3 9 6 9 2 0 .

TCP關閉連接(為什么會能Time_wait,Close_wait?)

轉載自https://www.qcloud.com/community/article/102

Tcp關閉連接問題及注意

最近一段時間一直在學習閱讀mina和nio的源碼,也發現了一些問題無法解決,然后重讀了一下tcp協議,收獲頗多。(這就是帶著問題去讀書的好處

這次就和大家分享一下我們的netframework服務總會拋出一個“connet reset by peer”的原因吧。通過抓包工具分析,主動關閉方直接發送了一個RST flags,而非FIN。就終止連接了。如下圖所示:

為什么調用sokcet的close時只通過一次握手就終結連接了?

要分析這個原因那就得從關閉連接程的四次握手,有時也會是三次握手,說起。如下圖所示:

大家都知道tcp正常的關閉連接要經過四次握手。如下所示:

在這四次握手狀態中,有一個特別要注意的狀態TIME_WAIT這個狀態是主動關閉方在收到被關閉方的FIN后會處于并長期(2個MSL時間,根據具體的實現不同,這個值會不同,在RFC 1122建議MSL=2分鐘,但在Berkeley的實現上使用的值為30s,具體可以看www.rfc.net ,要是沒有耐心去看英文的可以看這個網站www.cnpaf.net 里面有協議說明以及相應的源碼,java源碼中我沒有發現這個值,我只能追蹤到PlainSocketImpl.java這個類,再往下就是本地接口調用了,因此它是依賴本地操作系統的實現)處于的一個狀態也就是大約1-4分鐘,然后由操作系統自動回收并將TCP連接設為CLOSED初始狀態。如下圖所示:

然而在socket的處于TIME_WAIT狀態之后到它結束之前,該socket所占用的本地端口號將一直無法釋放,因此服務在高并發高負載下運行一段時間后,就常常會出現做為客戶端的程序無法向服務端建立新的socket連接的情況,過了1~4分鐘之后,客戶又可以連接上了,沒多久又連接不上,再等1~4分鐘之后又可以連接上,(上一個星期我們在做一個服務切換時遇到了這種情況)

這是因為服務方socket資源已經耗盡。netstat命令查看系統將會發現機器上存在大量處于TIME_WAIT狀態的socket連接,我這邊曾經出現達到了2w多個,并且占用大量的本地端口號。而此時機器上的可用本地端口號被占完,舊的大量處于TIME_WAIT狀態的socket尚未被系統回收時,就會出現無法向服務端創建新的socket連接的情況。只能過2分鐘之后等系統回收這些socket和端口資源之后才能服務,就這樣往復下去。

TCP為什么要這么要讓這種TIME_WAIT狀態存活這么久呢?其原因有兩個(參考stevens的unix網絡編程卷1 第38頁):

  1. 可靠地實現TCP全雙工連接的終止。(確保最后的ACK能讓被關閉方接收)
  2. 允許老的重復分節在網絡中消逝。(TCP中是可靠的服務,當數據包丟失會重傳,當有數據包迷路的情況下,如果不等待2MSL時,當客戶端以同樣地方式重新和服務建立連接后,上一次迷路的數據包這時可能會到達服務,這時會造成舊包被重新讀取)

解決方法:

1、(推薦方法,只能治標不治本)重用本地端口設置SO_REUSEADDR和SO_REUSEPORT(stevens的unix網絡編程卷1 第179~182頁)有詳情的講解,這樣就可以允許同一端口上啟動同一服務器的多個實例。怎樣理解呢?說白了就是即使socket斷了,重新調用前面的socket函數不會再去占用新的一個,而是始終就是一個端口,這樣防止socket始終連接不上,會不斷地換新端口。Java 中通過調用Socket的setReuseAddress,詳細可以查看java.net.Socket源碼。【這個地方會有風險,具體可以看(stevens的unix網絡編程卷1 第181頁)

2、修改內核TIME_WAIT等待的值,如果客戶端和服務器都在同個路由器下,這個是非常推薦的。(鏈路好,重傳機率低)

3、(不推崇,但目前我們是這樣做的,這個是造成(“connet reset by peer”)的元兇)設置SO_LINGER的值,java中是調用socket的 setSoLinger目前我們是設置為0的。設置為這個值的意思是當主動關閉方設置了setSoLinger(true,0)時,并調用close后,立該發送一個RST標志給對端,該TCP連接將立刻夭折,無論是否有排隊數據未發送或未被確認。這種關閉方式稱為“強行關閉”,而后套接字的虛電路立即被復位,尚未發出的所有數據都會丟失。而被動關閉方卻不知道對端已經徹底斷開。當被動關閉方正阻塞在recv()調用上時,接受到RST時,會立刻得到一個“connet reset by peer”的異常(即對端已經關閉),c中是返回一個EPEERRST錯。

為什么不推崇這種方法在(stevens的unix網絡編程卷1 第173頁)有詳細的講解。因為TIME_WAIT狀態是我們的朋友,它是有助有我們的(也就是說,它會讓舊的重復分節在網絡中超時消失(當我們的鏈路越長,ISP復雜的情況下(從網通到教育網的ping包用了9000ms),重復的分節的比例是非常高的。))。而且我們主動關閉連接方大都是由客戶端發起的(除了HTTP服務和異常),而且客戶方一般都不會有持續的大并發請求。 因此對資源沒有這么苛刻要求。

轉載請注明出處: 騰云閣 https://www.qcloud.com/community

posted on 2016-11-02 10:03 楊粼波 閱讀(1008) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲小说欧美另类婷婷| 亚洲尤物在线| 欧美不卡视频一区| 久久网站免费| 91久久精品视频| 亚洲久久在线| 国产精品播放| 久久国产乱子精品免费女| 伊人婷婷久久| 亚洲国产天堂久久国产91| 在线一区亚洲| 免费观看一级特黄欧美大片| 亚洲高清中文字幕| 亚洲国产精品成人综合色在线婷婷 | 久久久999国产| 亚洲激情二区| 亚洲啪啪91| 国产精品羞羞答答| 久久伊人亚洲| 欧美精品v国产精品v日韩精品| 亚洲人成网站精品片在线观看 | 欧美成人精品在线视频| 亚洲视频电影在线| 久久国产精品99久久久久久老狼| 欧美中文字幕不卡| 夜夜嗨av一区二区三区网站四季av| 亚洲人体一区| 国产欧美一区二区精品性| 欧美大香线蕉线伊人久久国产精品| 欧美国产日韩在线| 久久av二区| 欧美第十八页| 久久久噜噜噜久久中文字幕色伊伊| 欧美成人中文字幕在线| 欧美一区二区在线看| 免费毛片一区二区三区久久久| 亚洲影视在线| 美女主播一区| 久久久久成人精品免费播放动漫| 欧美成人精品1314www| 欧美一站二站| 欧美视频一区二| 亚洲国产精品一区二区www| 国产日韩在线亚洲字幕中文| 亚洲欧洲精品一区二区三区| 激情成人综合网| 中文av一区特黄| 亚洲精品欧美日韩| 久久久噜噜噜| 欧美一区二区三区啪啪| 欧美三级视频| 91久久极品少妇xxxxⅹ软件| 狠狠久久综合婷婷不卡| 亚洲欧美另类在线观看| 中文精品视频| 欧美另类专区| 亚洲成人资源网| 亚洲第一网站| 欧美一区久久| 久久国产一区二区| 国产精品一区在线观看你懂的| 亚洲精品在线观看视频| 最新亚洲一区| 欧美黄色精品| 亚洲韩国一区二区三区| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美影院成人| 猫咪成人在线观看| 激情综合五月天| 久久国产直播| 久久香蕉国产线看观看av| 国产日韩欧美一区二区三区四区| 一本久久综合亚洲鲁鲁| 一区二区三区日韩欧美精品| 欧美日韩精品福利| 一本色道久久综合狠狠躁篇的优点| a4yy欧美一区二区三区| 欧美日韩国产高清视频| 亚洲精品一区二区网址| 亚洲一区在线直播| 国产免费观看久久| 久久久国产视频91| 亚洲第一综合天堂另类专| 亚洲人成网站在线播| 欧美日韩久久不卡| 99精品国产在热久久婷婷| 欧美亚洲日本一区| 国产在线观看精品一区二区三区| 欧美一区二区福利在线| 免费成年人欧美视频| av成人免费在线观看| 国产精品久久精品日日| 久久福利毛片| 欧美激情免费在线| 亚洲一区二三| 国产亚洲美州欧州综合国| 久久精品视频va| 亚洲精品欧美专区| 久久国产主播精品| 日韩亚洲精品在线| 国产精品永久免费| 免费亚洲电影在线| 在线视频中文亚洲| 久久综合成人精品亚洲另类欧美| 亚洲精品一区在线| 国产精品一二| 欧美激情a∨在线视频播放| 中文亚洲免费| 亚洲第一福利社区| 欧美在线视频二区| 一本色道久久加勒比88综合| 国产日韩欧美三级| 欧美日韩91| 久久久999精品免费| 亚洲视频成人| 亚洲人成精品久久久久| 久久一区欧美| 午夜免费日韩视频| 99在线精品观看| 亚洲国产精品悠悠久久琪琪| 国产精品人人做人人爽| 美女日韩在线中文字幕| 亚洲欧美日韩综合一区| 亚洲精品国产精品乱码不99| 欧美在线视频一区二区三区| 在线一区二区三区四区五区| 亚洲国产欧美精品| 国内外成人免费激情在线视频网站 | 久久精品视频播放| 午夜精品久久久久久久蜜桃app| 亚洲国产日韩欧美在线动漫| 蜜臀av一级做a爰片久久| 欧美在线黄色| 香蕉亚洲视频| 午夜精品福利一区二区三区av | 国产午夜精品一区理论片飘花| 欧美日韩国产精品自在自线| 欧美sm极限捆绑bd| 久热re这里精品视频在线6| 久久久久国色av免费观看性色| 亚洲免费综合| 亚洲欧美日韩成人| 午夜日本精品| 亚洲综合精品一区二区| 亚洲一区国产视频| 亚洲欧美一级二级三级| 亚洲一区国产| 午夜精品999| 欧美在线播放| 久久成人精品| 久久夜色精品亚洲噜噜国产mv| 久久裸体艺术| 你懂的视频欧美| 欧美人交a欧美精品| 国产精品白丝黑袜喷水久久久 | 久久9热精品视频| 久久久久国产一区二区三区| 亚洲欧美日韩在线观看a三区| 国产精品福利网| 久久国产精品久久久| 欧美在线电影| 久久亚洲春色中文字幕| 你懂的国产精品| 欧美三级在线播放| 国产日韩精品入口| 在线免费观看日本一区| 亚洲欧洲精品一区二区三区不卡| 99国产精品久久久久老师| 亚洲欧美日韩中文播放| 久久精品99国产精品酒店日本| 久久亚洲欧美国产精品乐播| 欧美黄色精品| 亚洲尤物在线| 蜜臀久久99精品久久久画质超高清| 欧美黑人一区二区三区| 国产乱理伦片在线观看夜一区| 在线电影欧美日韩一区二区私密| 亚洲精品在线一区二区| 亚洲摸下面视频| 欧美福利在线| 亚洲欧美日韩视频一区| 欧美成人第一页| 国产精品国产三级国产aⅴ入口| 国产真实精品久久二三区| 亚洲免费电影在线观看| 欧美一区影院| 亚洲人成在线影院| 欧美在线一区二区三区| 欧美日本成人| 一区二区三区亚洲| 亚洲欧美日韩综合aⅴ视频| 欧美freesex交免费视频| 亚洲婷婷综合久久一本伊一区| 久久五月激情| 国产亚洲亚洲| 亚洲一区二区精品视频| 欧美国产日产韩国视频| 欧美综合二区| 国产欧美精品久久| 一区二区三区成人精品|