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

大龍的博客

常用鏈接

統計

最新評論

tcp_tw_recycle和tcp_timestamps導致connect失敗問題 --- 轉

 
   近來線上陸續出現了一些connect失敗的問題,經過分析試驗,最終確認和proc參數tcp_tw_recycle/tcp_timestamps相關;
1. 現象
    第一個現象:模塊A通過NAT網關訪問服務S成功,而模塊B通過NAT網關訪問服務S經常性出現connect失敗,抓包發現:服務S端已經收到了syn包,但沒有回復synack;另外,模塊A關閉了tcp timestamp,而模塊B開啟了tcp timestamp;
    第二個現象:不同主機上的模塊C(開啟timestamp),通過NAT網關(1個出口ip)訪問同一服務S,主機C1 connect成功,而主機C2 connect失敗;

2. 分析
    根據現象上述問題明顯和tcp timestmap有關;查看linux 2.6.32內核源碼,發現tcp_tw_recycle/tcp_timestamps都開啟的條件下,60s內同一源ip主機的socket connect請求中的timestamp必須是遞增的。
    源碼函數:tcp_v4_conn_request(),該函數是tcp層三次握手syn包的處理函數(服務端);
    源碼片段
       if (tmp_opt.saw_tstamp &&
            tcp_death_row.sysctl_tw_recycle &&
            (dst = inet_csk_route_req(sk, req)) != NULL &&
            (peer = rt_get_peer((struct rtable *)dst)) != NULL &&
            peer->v4daddr == saddr) {
            if (get_seconds() < peer->tcp_ts_stamp + TCP_PAWS_MSL &&
                (s32)(peer->tcp_ts - req->ts_recent) >
                            TCP_PAWS_WINDOW) {
                NET_INC_STATS_BH(sock_net(sk), LINUX_MIB_PAWSPASSIVEREJECTED);
                goto drop_and_release;
            }
        }
        tmp_opt.saw_tstamp:該socket支持tcp_timestamp
        sysctl_tw_recycle:本機系統開啟tcp_tw_recycle選項
        TCP_PAWS_MSL:60s,該條件判斷表示該源ip的上次tcp通訊發生在60s內
        TCP_PAWS_WINDOW:1,該條件判斷表示該源ip的上次tcp通訊的timestamp 大于 本次tcp


    分析:主機client1和 client2通過NAT網關(1個ip地址)訪問serverN,由于timestamp時間為系統啟動到當前的時間,因此,client1和 client2的timestamp不相同;根據上述syn包處理源碼,在tcp_tw_recycle和tcp_timestamps同時開啟的條件 下,timestamp大的主機訪問serverN成功,而timestmap小的主機訪問失敗;

    參數:/proc/sys/net/ipv4/tcp_timestamps - 控制timestamp選項開啟/關閉
          /proc/sys/net/ipv4/tcp_tw_recycle - 減少timewait socket釋放的超時時間

3. 解決方法
    echo 0 > /proc/sys/net/ipv4/tcp_tw_recycle;
    tcp_tw_recycle默認是關閉的,有不少服務器,為了提高性能,開啟了該選項;
    為了解決上述問題,個人建議關閉tcp_tw_recycle選項,而不是timestamp;因為 在tcp timestamp關閉的條件下,開啟tcp_tw_recycle是不起作用的;而tcp timestamp可以獨立開啟并起作用。
    源碼函數:  tcp_time_wait()
    源碼片段:
        if (tcp_death_row.sysctl_tw_recycle && tp->rx_opt.ts_recent_stamp)
            recycle_ok = icsk->icsk_af_ops->remember_stamp(sk);
        ......
       
        if (timeo < rto)
            timeo = rto;

        if (recycle_ok) {
            tw->tw_timeout = rto;
        } else {
            tw->tw_timeout = TCP_TIMEWAIT_LEN;
            if (state == TCP_TIME_WAIT)
                timeo = TCP_TIMEWAIT_LEN;
        }

        inet_twsk_schedule(tw, &tcp_death_row, timeo,
                   TCP_TIMEWAIT_LEN);

    timestamp和tw_recycle同時開啟的條件下,timewait狀態socket釋放的超時時間和rto相關;否則,超時時間為TCP_TIMEWAIT_LEN,即60s;

    內核說明文檔 對該參數的介紹如下
    tcp_tw_recycle - BOOLEAN
    Enable fast recycling TIME-WAIT sockets. Default value is 0.
    It should not be changed without advice/request of technical
    experts.

posted on 2013-02-17 18:58 大龍 閱讀(369) 評論(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>
            在线观看日韩av先锋影音电影院| 国产视频在线观看一区二区三区| 亚洲国产精品精华液网站| 久久免费99精品久久久久久| 午夜老司机精品| 国产亚洲成年网址在线观看| 久久人人爽爽爽人久久久| 欧美亚洲视频在线看网址| 国产一区二区三区的电影| 美女被久久久| 欧美剧在线观看| 亚洲欧美国产不卡| 欧美亚洲视频在线观看| 亚洲风情亚aⅴ在线发布| 亚洲第一久久影院| 欧美理论电影在线观看| 亚洲欧美99| 久久精品视频网| 一区二区三区成人| 欧美专区日韩专区| 亚洲国产裸拍裸体视频在线观看乱了中文 | 国产亚洲观看| 亚洲国产成人在线播放| 欧美午夜激情视频| 久久久久综合网| 欧美日韩一二三四五区| 久久国产精品电影| 欧美成人免费在线观看| 欧美在线视屏| 欧美成人中文字幕| 久久成人免费日本黄色| 欧美大片一区二区| 亚洲欧美日韩一区二区三区在线观看 | 国产欧美亚洲精品| 欧美激情在线狂野欧美精品| 欧美日韩综合另类| 六月婷婷久久| 国产伦精品一区二区三区照片91| 久久久久久电影| 久久成年人视频| 欧美大片免费观看| 久久九九99视频| 欧美性大战久久久久| 美日韩精品免费| 国产精品一区二区久久| 亚洲激情av| 激情综合网址| 小黄鸭视频精品导航| 99re66热这里只有精品4| 欧美一区影院| 午夜亚洲影视| 欧美日韩一区在线| 亚洲黄色影片| 亚洲国产99| 久久精品一区二区三区中文字幕| 亚洲图片在区色| 欧美a级在线| 欧美xxx在线观看| 激情一区二区三区| 欧美一二三视频| 欧美一级一区| 国产精品视频九色porn| 99国产精品一区| 亚洲日本成人| 欧美成人性网| 亚洲福利视频网站| 亚洲高清免费视频| 久久久亚洲一区| 久久婷婷影院| 伊人久久综合97精品| 欧美有码在线观看视频| 久久久久一区二区三区四区| 国内精品视频666| 久久久人成影片一区二区三区观看| 久久精品视频在线看| 好吊妞这里只有精品| 亚洲无线视频| 久久精品系列| 一区视频在线看| 欧美91福利在线观看| 亚洲国产另类久久久精品极度| 亚洲激情一区| 欧美视频一区| 午夜精品久久久久久| 久久免费视频网| 亚洲激情欧美激情| 欧美精品国产| 亚洲视频在线观看一区| 欧美在线亚洲| 亚洲二区视频在线| 欧美激情一区二区三区| 一区二区三区精品国产| 久久精品道一区二区三区| 1000部国产精品成人观看| 欧美成人dvd在线视频| 一本色道精品久久一区二区三区| 欧美一区二区三区四区在线观看地址| 黄色免费成人| 欧美日本免费| 久久国产免费| 亚洲精品在线电影| 久久精品国产99| 亚洲美女性视频| 国产欧美日韩精品丝袜高跟鞋| 久久色在线观看| 亚洲小说欧美另类婷婷| 欧美电影电视剧在线观看| 亚洲一区二区三区成人在线视频精品 | 亚洲一区二区三区在线播放| 久久夜色撩人精品| 亚洲一级网站| 在线观看国产成人av片| 国产精品劲爆视频| 美国十次了思思久久精品导航| 一区二区三区色| 男女av一区三区二区色多| 亚洲免费在线电影| 亚洲精品免费电影| 激情久久久久久| 国产精品美女久久福利网站| 鲁大师成人一区二区三区| 亚洲欧美视频在线观看视频| 亚洲免费观看高清在线观看 | 亚洲婷婷综合色高清在线| 欧美成人高清视频| 久久精品国产欧美亚洲人人爽| 亚洲桃花岛网站| 亚洲精品影院| 亚洲高清毛片| 亚洲国产高清高潮精品美女| 国产欧美精品在线| 国产精品第一区| 欧美日韩大片| 免费日韩成人| 裸体素人女欧美日韩| 久久久久久高潮国产精品视| 亚洲欧美日韩一区二区三区在线观看| 亚洲乱码久久| 亚洲级视频在线观看免费1级| 男同欧美伦乱| 欧美 日韩 国产精品免费观看| 久久久久免费视频| 久久久久99| 久久久久久久综合日本| 久久精品在线免费观看| 久久成人精品| 久久精品人人做人人爽电影蜜月| 欧美在线不卡| 久久高清免费观看| 久久99在线观看| 久久成人亚洲| 久久男女视频| 女主播福利一区| 欧美国产精品| 亚洲精品一线二线三线无人区| 91久久精品视频| 日韩视频一区二区| 亚洲特色特黄| 欧美亚洲综合久久| 久久婷婷综合激情| 欧美不卡福利| 欧美视频1区| 国产一区二区三区视频在线观看 | 欧美激情片在线观看| 欧美极品欧美精品欧美视频| 欧美精品午夜| 国产精品一区二区在线观看不卡 | 欧美高清视频| 国产精品h在线观看| 国产日韩一区| 亚洲日本欧美天堂| 亚洲一区二区久久| 久久久激情视频| 欧美激情视频网站| 亚洲美女精品成人在线视频| 亚洲一区二区三区777| 欧美在线你懂的| 欧美激情中文字幕乱码免费| 国产精品都在这里| 国内精品99| 亚洲视频在线观看网站| 久久av一区| 亚洲激情电影中文字幕| 亚洲欧美激情视频| 欧美成人精品在线| 国产精品区二区三区日本 | 欧美激情成人在线| 国产精品亚洲综合| 亚洲高清免费| 久久精品国产亚洲高清剧情介绍| 欧美成人综合一区| 亚洲综合色婷婷| 欧美日韩高清在线播放| 黄色欧美日韩| 亚洲欧美激情在线视频| 亚洲大片在线观看| 欧美一区=区| 欧美午夜视频在线| 亚洲精品一区二区三区婷婷月| 久久精品99国产精品酒店日本|