• <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++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            網(wǎng)絡(luò)連接無法釋放—— CLOSE_WAIT

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

            問題描述:最近性能測試碰到的一個問題。客戶端使用NIO,服務(wù)器還是一般的Socket連接。當(dāng)測試進(jìn)行一段時間以后,發(fā)現(xiàn)服務(wù)器端的系統(tǒng)出現(xiàn)大量未釋放的網(wǎng)絡(luò)連接。用netstat -na查看,連接狀態(tài)為CLOSE_WAIT。這就奇怪了,為什么Socket已經(jīng)關(guān)閉而連接依然未釋放。

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

            時間基本上花在Google上了,不過也學(xué)到不少東西。下面為一張TCP連接的狀態(tài)轉(zhuǎn)換圖:

             

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

            結(jié)合上圖使用netstat -na命令即可知道到當(dāng)前的TCP連接狀態(tài)。一般LISTEN、ESTABLISHED、TIME_WAIT是比較常見。

            分析:

            上面我碰到的這個問題主要因為TCP的結(jié)束流程未走完,造成連接未釋放?,F(xiàn)設(shè)客戶端主動斷開連接,流程如下

                   Client                            消息                                    Server

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

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

            如上圖所示,由于Server的Socket在客戶端已經(jīng)關(guān)閉時而沒有調(diào)用關(guān)閉,造成服務(wù)器端的連接處在“掛起”狀態(tài),而客戶端則處在等待應(yīng)答的狀態(tài)上。此問題的典型特征是:一端處于FIN_WAIT2 ,而另一端處于CLOSE_WAIT. 不過,根本問題還是程序?qū)懙牟缓?,有待提高?/p>

            亚洲精品国产综合久久一线| 国产韩国精品一区二区三区久久| 久久人人爽人人爽人人片AV东京热| 精品久久久久一区二区三区 | 久久久噜噜噜www成人网| 无码国内精品久久人妻| 国产成人精品久久一区二区三区av | 久久www免费人成看片| 久久Av无码精品人妻系列| 久久国产成人亚洲精品影院| 色偷偷偷久久伊人大杳蕉| 久久精品国产72国产精福利| 久久亚洲精精品中文字幕| 亚洲欧美日韩久久精品| 欧美精品一本久久男人的天堂| 综合久久给合久久狠狠狠97色| 久久久91精品国产一区二区三区| 99久久香蕉国产线看观香| 久久国产亚洲精品麻豆| 久久久久久九九99精品| 漂亮人妻被中出中文字幕久久| 久久九九亚洲精品| 精品免费久久久久久久| 精品久久久无码21p发布| 久久久精品波多野结衣| 伊人久久大香线焦综合四虎| 久久久亚洲欧洲日产国码aⅴ| 久久久久人妻一区二区三区| 思思久久99热免费精品6| 久久久久国产视频电影| 91久久成人免费| 欧美久久精品一级c片片| 青青青国产精品国产精品久久久久 | 久久er国产精品免费观看2| 亚洲精品乱码久久久久久蜜桃不卡| 久久婷婷色综合一区二区| 国内精品久久久久久麻豆| 久久福利片| 综合久久精品色| 久久亚洲私人国产精品vA| 久久久一本精品99久久精品66|