• <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久久国产亚洲综合精品| 久久人妻少妇嫩草AV蜜桃| 久久精品国产免费观看| 久久精品a亚洲国产v高清不卡| 精品久久国产一区二区三区香蕉| 香蕉久久夜色精品国产2020| 99久久人妻无码精品系列| 久久996热精品xxxx| 亚洲∧v久久久无码精品| 久久国产三级无码一区二区| 久久久国产精华液| 国产精品免费久久久久影院| 亚洲成色WWW久久网站| 99久久精品国产一区二区| 无码人妻精品一区二区三区久久| 91精品免费久久久久久久久| 亚洲中文字幕久久精品无码APP| 国产亚洲婷婷香蕉久久精品| 亚洲AV无码久久精品色欲| 久久有码中文字幕| 国产精品99久久久久久猫咪| 九九久久自然熟的香蕉图片| 久久精品aⅴ无码中文字字幕不卡 久久精品成人欧美大片 | 久久综合久久综合久久综合| 伊人久久大香线蕉亚洲五月天| 久久噜噜久久久精品66| 精品久久久无码中文字幕| 久久99免费视频| 国产精品久久久久久搜索| 久久久精品2019免费观看| 亚洲日本va中文字幕久久| 99久久国产精品免费一区二区 | 久久久久久久精品成人热色戒 | 久久男人AV资源网站| 久久激情五月丁香伊人| 亚洲国产精品人久久| 精品99久久aaa一级毛片| 狠狠色综合网站久久久久久久|