• <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>

            Prayer

            在一般中尋求卓越
            posts - 1256, comments - 190, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            網絡連接無法釋放—— CLOSE_WAIT

            Posted on 2009-04-11 13:54 Prayer 閱讀(2782) 評論(0)  編輯 收藏 引用 所屬分類: SOCKET

            問題描述:最近性能測試碰到的一個問題。客戶端使用NIO,服務器還是一般的Socket連接。當測試進行一段時間以后,發現服務器端的系統出現大量未釋放的網絡連接。用netstat -na查看,連接狀態為CLOSE_WAIT。這就奇怪了,為什么Socket已經關閉而連接依然未釋放。

            解決:Google了半天,發現關于CLOSE_WAIT的問題一般是C的,Java似乎碰到這個問題的不多(這有一篇不錯的,也是解決CLOSE_WAIT的,但是好像沒有根本解決,而是選擇了一個折中的辦法)。接著找,由于使用了NIO,所以懷疑可能是這方面的問題,結果找到了這篇。順著帖子翻下去,其中有幾個人說到了一個問題—— 一端的Socket調用close后,另一端的Socket沒有調用close.于是查了一下代碼,果然發現Server端在某些異常情況時,沒有關閉Socket。改正后問題解決。

            時間基本上花在Google上了,不過也學到不少東西。下面為一張TCP連接的狀態轉換圖:

             

            說明:虛線和實線分別對應服務器端(被連接端)和客戶端端(主動連接端)。

            結合上圖使用netstat -na命令即可知道到當前的TCP連接狀態。一般LISTEN、ESTABLISHED、TIME_WAIT是比較常見。

            分析:

            上面我碰到的這個問題主要因為TCP的結束流程未走完,造成連接未釋放。現設客戶端主動斷開連接,流程如下

                   Client                            消息                                    Server

                     close()
                                                  ------ FIN ------->
                    FIN_WAIT1                                                         CLOSE_WAIT
                                                  <----- ACK -------
                    FIN_WAIT2 
                                                                                              close()
                                                   <------ FIN ------                     
                    TIME_WAIT                                                       LAST_ACK      

                                                  ------ ACK ------->  
                                                                                               CLOSED
                       CLOSED

            如上圖所示,由于Server的Socket在客戶端已經關閉時而沒有調用關閉,造成服務器端的連接處在“掛起”狀態,而客戶端則處在等待應答的狀態上。此問題的典型特征是:一端處于FIN_WAIT2 ,而另一端處于CLOSE_WAIT. 不過,根本問題還是程序寫的不好,有待提高。

            久久久中文字幕日本| 亚洲精品蜜桃久久久久久| 亚洲一本综合久久| 久久综合九色综合久99| 欧美精品一区二区久久| 香蕉久久夜色精品升级完成| 精品久久久久久无码专区| 精品久久久久久综合日本| 无码人妻少妇久久中文字幕| 日产精品99久久久久久| 久久精品无码一区二区三区日韩| 中文字幕日本人妻久久久免费| 久久久久久狠狠丁香| 国产精品久久婷婷六月丁香| 久久精品国产秦先生| 色妞色综合久久夜夜| 亚洲国产精品综合久久一线| 狠狠狠色丁香婷婷综合久久五月 | 亚洲伊人久久综合影院| 国产精品免费福利久久| 国产99久久久国产精品小说| 99久久成人国产精品免费| 久久久久亚洲AV无码专区首JN | av色综合久久天堂av色综合在 | 亚洲AV无码久久寂寞少妇| 国产高清国内精品福利99久久| 午夜不卡久久精品无码免费| 婷婷久久综合九色综合九七| 国产高潮国产高潮久久久91| 久久精品一区二区国产| 日产精品久久久一区二区| 亚洲AV无码久久精品狠狠爱浪潮| 亚洲国产精品嫩草影院久久 | 亚洲日本久久久午夜精品| 久久精品国产72国产精福利| 国产精品久久国产精品99盘| 久久久久久人妻无码| 91精品国产高清久久久久久io| 久久大香香蕉国产| 99国产精品久久| 曰曰摸天天摸人人看久久久|