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

            大龍的博客

            常用鏈接

            統(tǒng)計(jì)

            最新評(píng)論

            tcp_tw_recycle和tcp_timestamps導(dǎo)致connect失敗問(wèn)題 --- 轉(zhuǎn)

             
               近來(lái)線上陸續(xù)出現(xiàn)了一些connect失敗的問(wèn)題,經(jīng)過(guò)分析試驗(yàn),最終確認(rèn)和proc參數(shù)tcp_tw_recycle/tcp_timestamps相關(guān);
            1. 現(xiàn)象
                第一個(gè)現(xiàn)象:模塊A通過(guò)NAT網(wǎng)關(guān)訪問(wèn)服務(wù)S成功,而模塊B通過(guò)NAT網(wǎng)關(guān)訪問(wèn)服務(wù)S經(jīng)常性出現(xiàn)connect失敗,抓包發(fā)現(xiàn):服務(wù)S端已經(jīng)收到了syn包,但沒(méi)有回復(fù)synack;另外,模塊A關(guān)閉了tcp timestamp,而模塊B開啟了tcp timestamp;
                第二個(gè)現(xiàn)象:不同主機(jī)上的模塊C(開啟timestamp),通過(guò)NAT網(wǎng)關(guān)(1個(gè)出口ip)訪問(wèn)同一服務(wù)S,主機(jī)C1 connect成功,而主機(jī)C2 connect失敗;

            2. 分析
                根據(jù)現(xiàn)象上述問(wèn)題明顯和tcp timestmap有關(guān);查看linux 2.6.32內(nèi)核源碼,發(fā)現(xiàn)tcp_tw_recycle/tcp_timestamps都開啟的條件下,60s內(nèi)同一源ip主機(jī)的socket connect請(qǐng)求中的timestamp必須是遞增的。
                源碼函數(shù):tcp_v4_conn_request(),該函數(shù)是tcp層三次握手syn包的處理函數(shù)(服務(wù)端);
                源碼片段
                   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:本機(jī)系統(tǒng)開啟tcp_tw_recycle選項(xiàng)
                    TCP_PAWS_MSL:60s,該條件判斷表示該源ip的上次tcp通訊發(fā)生在60s內(nèi)
                    TCP_PAWS_WINDOW:1,該條件判斷表示該源ip的上次tcp通訊的timestamp 大于 本次tcp


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

                參數(shù):/proc/sys/net/ipv4/tcp_timestamps - 控制timestamp選項(xiàng)開啟/關(guān)閉
                      /proc/sys/net/ipv4/tcp_tw_recycle - 減少timewait socket釋放的超時(shí)時(shí)間

            3. 解決方法
                echo 0 > /proc/sys/net/ipv4/tcp_tw_recycle;
                tcp_tw_recycle默認(rèn)是關(guān)閉的,有不少服務(wù)器,為了提高性能,開啟了該選項(xiàng);
                為了解決上述問(wèn)題,個(gè)人建議關(guān)閉tcp_tw_recycle選項(xiàng),而不是timestamp;因?yàn)?在tcp timestamp關(guān)閉的條件下,開啟tcp_tw_recycle是不起作用的;而tcp timestamp可以獨(dú)立開啟并起作用。
                源碼函數(shù):  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同時(shí)開啟的條件下,timewait狀態(tài)socket釋放的超時(shí)時(shí)間和rto相關(guān);否則,超時(shí)時(shí)間為TCP_TIMEWAIT_LEN,即60s;

                內(nèi)核說(shuō)明文檔 對(duì)該參數(shù)的介紹如下
                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 大龍 閱讀(360) 評(píng)論(0)  編輯 收藏 引用


            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            精品久久久久久无码中文字幕 | 亚洲国产婷婷香蕉久久久久久| 国产亚洲美女精品久久久久狼| 亚洲第一极品精品无码久久| 久久99九九国产免费看小说| 亚洲精品WWW久久久久久| 久久久久亚洲精品男人的天堂| 亚洲国产成人精品91久久久| 无码精品久久一区二区三区 | 色偷偷88888欧美精品久久久| 人妻少妇久久中文字幕| 久久99精品久久久久子伦| 久久中文娱乐网| 国产成人久久精品二区三区| 人妻丰满?V无码久久不卡| 无码人妻少妇久久中文字幕蜜桃| 青青草原精品99久久精品66| 国产V综合V亚洲欧美久久 | 曰曰摸天天摸人人看久久久| 久久国产精品免费一区| 久久婷婷是五月综合色狠狠| 国产精品久久久久9999高清| 国产成人综合久久久久久| 青青草原综合久久大伊人| 欧美日韩中文字幕久久伊人| 久久夜色精品国产www| 国内精品久久久久久99蜜桃 | 久久精品国产精品亚洲下载| 久久中文字幕精品| 久久国产免费观看精品3| 久久大香萑太香蕉av| 99久久精品国产麻豆| 欧美777精品久久久久网| 亚洲国产成人久久综合一区77| 国内精品久久久久影院一蜜桃| 青春久久| 久久国产精品成人影院| 久久人人爽人人人人爽AV| 久久91精品综合国产首页| 久久91精品国产91久久麻豆| 性做久久久久久久|