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

大龍的博客

常用鏈接

統計

最新評論

幾個重要的TCP/IP選項解析(Java Socket)

1. SO_LINGER / SO_REUSEADDR
    TCP正常的關閉過程如下(四次握手過程):
(FIN_WAIT_1) A       ---FIN--->       B(CLOSE_WAIT)
(FIN_WAIT_2) A       <--ACK--       B(CLOSE_WAIT)
  (TIME_WAIT)A        <--FIN----       B(LAST_ACK)
  (TIME_WAIT)A        ---ACK->       B(CLOSED)
    Ø  A端首先發送一個FIN請求給B端,要求關閉,發送后A段的TCP狀態變更為FIN_WAIT_1,接收到FIN請求后B端的TCP狀態變更為CLOSE_WAIT
    Ø  B接收到ACK請求后,B回一個ACK給A端,確認接收到的FIN請求,接收到ACK請求后,A端的TCP狀態變更為為FIN_WAIT_2。
    Ø  B端再發送一個FIN請求給A端,與連接過程的3次握手過程不一樣,這個FIN請求之所以并不是與上一個請求一起發送,之所以如此處理,是因為TCP是雙 通道的,允許在發送ACK請求后,并不馬上發FIN請求,即只關閉A到B端的數據流,仍然允許B端到A端的數據流。這個ACK請求發送之后,B端的TCP 狀態變更為LAST_ACK,A端的狀態變更為TIME_WAIT。
    Ø  A端接收到B端的FIN請求后,再回B端一個ACK信息,對上一個FIN請求進行確認,到此時B端狀態變更為CLOSED,Socket可以關閉。
   除了如上正常的關閉(優雅關閉)之外,TCP還提供了另外一種非優雅的關閉方式RST(Reset)
   (CLOSED) A         ---RST-->      B (CLOSED)
   Ø  A端發送RST狀態之后,TCP進入CLOSED狀態,B端接收到RST后,也即可進入CLOSED狀態。
    在第一種關閉方式上(優雅關閉),非常遺憾,A端在最后發送一個ACK請求后,并不能馬上將該Socket回收,因為A并不能確定B一定能夠接收到這個 ACK請求,因此A端必須對這個Socket維持TIME_WAIT狀態2MSL(MSL=Max Segment Lifetime,取決于操作系統和TCP實現,該值為30秒、60秒或2分鐘)。如果A端是客戶端,這并不會成為問題,但如果A端是服務端,那就很危險 了,如果連接的Socket非常多,而又維持如此多的TIME_WAIT狀態的話,那么有可能會將Socket耗盡(報Too Many Open File)。
    服務端為了解決這個問題,可選擇的方式有三種:
    Ø  保證由客戶端主動發起關閉(即做為B端)
    Ø  關閉的時候使用RST的方式
    Ø  對處于TIME_WAIT狀態的TCP允許重用
     一般我們當然最好是選擇第一種方式,實在沒有辦法的時候,我們可以使用SO_LINGER選擇第二種方式,使用SO_REUSEADDR選擇第三種方式

  1. public   void  setSoLinger( boolean  on,  int  linger)  throws  SocketException   
  2. public   void  setReuseAddress( boolean  on)  throws  SocketException   

    第一個on表示是否使用SO_LINGER選項,linger(以秒為單位)表示在發RST之前會等待多久,因為一旦發送RST,還在緩沖區中還沒有發送出去的數據就會直接丟棄


2.TCP_NODELAY
     對于交互型的應用(譬如telnet),經常存在的情況是客戶端和服務端之間需要頻繁地進行一些小數據交換,譬如telnet可能每敲一個鍵盤都需要將數 據發送到服務端。為了避免這種情況會產生大量小數據包,提出了Nagle算法。Nagle算法要求每次在發送端最后只有一個未被確認的包,因此上一個包發 送出去還沒有接收到響應之前,要求發送的包回先放在緩沖區,接收到響應之后,會將緩沖區中的包合并成一個包發送出去(可以看到,響應回地越快,發送出去的 數據也會越快)。
     需要注意的是,由Nagle算法要求只能有一個未被確認的包,因此窗口參數會失效,在大數據量傳送的情況下會使網絡吞吐量下降,因此對于大數據量的交互, 應該關閉Nagle算法,Nagle算法比較適合小數據量頻繁交換的情景。我們可以使用TCP_NODELAY關閉Nagle算法。

  1. public   void  setTcpNoDelay( boolean  on)  throws  SocketException  

3.SO_KEEPALIVE
     在一個TCP連接建立之后,我們會很奇怪地發現,默認情況下,如果一端異常退出(譬如網絡中斷后一端退出,使地關閉請求另一端無法接收到),TCP的另一 端并不能獲得這種情況,仍然會保持一個半關閉的連接,對于服務端,大量半關閉的連接將會是非常致命的。SO_KEEPALIVE提供了一種手段讓TCP的 一端(通常服務提供者端)可以檢測到這種情況。如果我們設置了SO_KEEPALIVE,TCP在距離上一次TCP包交互2個小時(取決于操作系統和 TCP實現,規范建議不低于2小時)后,會發送一個探測包給另一端,如果接收不到響應,則在75秒后重新發送,連續10次仍然沒有響應,則認為對方已經關 閉,系統會將該連接關閉。一般情況下,如果對方已經關閉,則對方的TCP層會回RST響應回來,這種情況下,同樣會將連接關閉。

public   void  setKeepAlive( boolean  on)  throws  SocketException 

posted on 2012-02-09 11:53 大龍 閱讀(669) 評論(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>
            日韩视频在线观看国产| 欧美人与禽性xxxxx杂性| 国产精品国产三级国产普通话蜜臀 | 久久国产福利| 久久精品国产久精国产思思| 欧美一级理论片| 免费在线观看一区二区| 国产精品入口麻豆原神| 久久精品网址| 一区电影在线观看| 久久久久久69| 亚洲午夜久久久久久久久电影院 | 欧美色偷偷大香| 久久激情网站| 中文日韩电影网站| 欧美福利精品| 久久久久国产精品人| 久久精品av麻豆的观看方式| 久久精品国亚洲| 免费不卡亚洲欧美| 亚洲精品网站在线播放gif| 久久精品亚洲一区| 免费成人你懂的| 亚洲激情第一页| 欧美精品情趣视频| 久久爱www| 一区二区三区鲁丝不卡| 午夜欧美不卡精品aaaaa| 最新日韩在线视频| 中文亚洲视频在线| 久久国产日韩欧美| 欧美精品成人在线| 国产日韩欧美精品| 国产精品老牛| 国产精品国产自产拍高清av王其 | 欧美伊人久久久久久午夜久久久久| 亚洲欧洲精品一区| 依依成人综合视频| 激情小说亚洲一区| 国产一区日韩二区欧美三区| 国产九区一区在线| 国产伦精品一区二区三区四区免费 | 欧美亚洲在线视频| 午夜精品一区二区三区在线| 在线一区亚洲| 亚洲视频在线观看| 亚洲影院色无极综合| 欧美日韩国产一区二区三区地区 | 午夜精品久久久久久久99樱桃| 亚洲女人av| 欧美一区二区三区四区高清| 欧美大片专区| 欧美久久久久免费| 黄色国产精品| 亚洲国产福利在线| 日韩亚洲欧美一区| 久久美女性网| 亚洲国产高清视频| 亚洲精品免费网站| 亚洲丝袜av一区| 午夜日本精品| 国产精品乱码一区二三区小蝌蚪| 亚洲黄一区二区三区| 在线视频你懂得一区 | 中文精品视频| 欧美日韩精品在线视频| 亚洲精品免费在线| 亚洲性感美女99在线| 亚洲高清不卡av| 久久男人av资源网站| 欧美老女人xx| 亚洲人成在线播放| 亚洲第一精品久久忘忧草社区| 久久久久久久网| 欧美日韩久久久久久| 国产精品一区二区久久精品| 亚洲一二三级电影| 中文欧美在线视频| 欧美午夜不卡视频| 在线 亚洲欧美在线综合一区| 久久av在线| 欧美中文在线视频| 狠狠色丁香婷综合久久| 久久夜色精品国产噜噜av| 欧美韩日亚洲| 欧美一级免费视频| 狠狠做深爱婷婷久久综合一区| 久久久精品2019中文字幕神马| 亚洲欧美国产日韩中文字幕| 国模私拍视频一区| 亚洲第一久久影院| 欧美视频在线观看免费| 欧美一级久久久久久久大片| 亚洲毛片在线观看.| 国产乱人伦精品一区二区| 噜噜噜久久亚洲精品国产品小说| 亚洲一区二区三区中文字幕在线| 国产精品影片在线观看| 久久精品国产久精国产思思| 蜜臀av一级做a爰片久久 | 亚洲国产免费看| 欧美日韩国产一区精品一区| 亚洲欧美日韩国产一区| 亚洲激情一区二区| 欧美日韩国语| 久久久久久夜| 欧美久久99| 久久免费高清| 欧美日韩在线视频首页| 久久成人一区二区| 欧美激情在线有限公司| 久久久夜夜夜| 欧美日韩一区二区三区高清| 欧美成人午夜77777| 国产伦理一区| 中文日韩欧美| 在线一区二区三区四区| 牛牛精品成人免费视频| 最新成人在线| 久久久精品日韩欧美| 午夜在线精品偷拍| 欧美日韩成人激情| 亚洲国产婷婷香蕉久久久久久| 欧美久久久久久久久久| 欧美成人免费观看| 国产日韩一区二区三区| 日韩亚洲一区在线播放| 国产精品毛片在线| 亚洲经典三级| 在线免费一区三区| 亚洲第一级黄色片| 国产精品久久久久久久久久久久 | 久久精品国产精品亚洲| 国产精品视频第一区| 亚洲欧洲美洲综合色网| 欧美黄色小视频| 国产酒店精品激情| 久久成人精品| 可以看av的网站久久看| 国产精品久久久久久久久借妻 | 亚洲国产精品va在线观看黑人 | 亚洲摸下面视频| 免费观看亚洲视频大全| 免费在线欧美视频| 欧美午夜理伦三级在线观看| 久久夜色精品一区| 欧美日韩国产一区| 亚洲精品乱码久久久久久| 亚洲国产精品成人综合色在线婷婷| 亚洲品质自拍| 国产精品一卡| 亚洲一区二区三区在线| 午夜精品免费在线| 日韩午夜中文字幕| 久久精品亚洲热| 欧美成熟视频| 国产日韩一区欧美| 亚洲看片一区| 在线观看福利一区| 欧美福利视频在线| 正在播放欧美一区| 久久综合网络一区二区| 欧美一区二区三区啪啪| 欧美日韩美女| 久久精品人人做人人爽| 亚洲国产成人精品女人久久久 | 亚洲综合国产| 亚洲视频福利| 美女网站久久| 久久久久免费观看| 国产日韩精品视频一区| 亚洲一区三区视频在线观看| 午夜宅男欧美| 欧美四级剧情无删版影片| 欧美国产精品| 亚洲激情啪啪| 欧美高清视频在线观看| 亚洲午夜精品国产| 亚洲天堂免费在线观看视频| 欧美精品123区| 91久久综合| 欧美日韩视频在线一区二区观看视频 | 久久亚洲精品一区二区| 久久久久久午夜| 国产精品日日摸夜夜摸av| 美女精品国产| 亚洲福利视频免费观看| 国产精品盗摄一区二区三区| 日韩一级欧洲| 亚洲影音先锋| 国产精品稀缺呦系列在线| 亚洲欧美视频在线观看视频| 亚洲免费视频网站| 国产精品一区二区在线观看网站| 久久综合色婷婷| 亚洲国产精品ⅴa在线观看| 亚洲精品日韩一| 欧美日韩国产经典色站一区二区三区| 亚洲午夜精品网| 亚洲少妇最新在线视频|