• <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>
            Fork me on GitHub
            隨筆 - 215  文章 - 13  trackbacks - 0
            <2017年4月>
            2627282930311
            2345678
            9101112131415
            16171819202122
            23242526272829
            30123456


            專注即時通訊及網游服務端編程
            ------------------------------------
            Openresty 官方模塊
            Openresty 標準模塊(Opm)
            Openresty 三方模塊
            ------------------------------------
            本博收藏大部分文章為轉載,并在文章開頭給出了原文出處,如有再轉,敬請保留相關信息,這是大家對原創作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            相冊

            Awesome

            Blog

            Book

            GitHub

            Link

            搜索

            •  

            積分與排名

            • 積分 - 215511
            • 排名 - 118

            最新評論

            閱讀排行榜

            https://my.oschina.net/shou1156226/blog/514929
            http://blog.csdn.net/weiweicao0429/article/details/17578011
            1. 模擬延遲傳輸簡介
                    netem 與 tc: netem 是 Linux 2.6 及以上內核版本提供的一個網絡模擬功能模塊。該功能模塊可以用來在性能良好的局域網中,模擬出復雜的互聯網傳輸性能,諸如低帶寬、傳輸延遲、丟包等等情 況。使用 Linux 2.6 (或以上) 版本內核的很多發行版 Linux 都開啟了該內核功能,比如 Fedora、Ubuntu、Redhat、OpenSuse、CentOS、Debian 等等。 tc 是Linux 系統中的一個工具,全名為 traffic control(流量控制)。tc 可以用來控制 netem 的工作模式,也就是說,如果想使用 netem ,需要至少兩個條件,一個是內核中的 netem 功能被包含,另一個是要有 tc 。

                    需要注意的是:本文介紹的流控只能控制發包動作,不能控制收包動作,同時,它直接對物理接口生效,如果控制了物理的 eth0,那么邏輯網卡(比如 eth0:1)也會受到影響,反之,如果您在邏輯網卡上做控制,該控制可能是無效的。(注:虛擬機中的多個網卡可以在虛擬機中視為多個物理網卡)。

            1)將 eth0 網卡的傳輸設置為延遲 100 毫秒發送
            # tc qdisc add dev eth0 root netem delay 100ms
            2)模擬出帶有波動性的延遲值:
            # tc qdisc add dev eth0 root netem delay 100ms 10ms
            該命令將 eth0 網卡的傳輸設置為延遲 100ms ± 10ms(90 ~ 110 ms之間的任意值)發送。

            3)還可以更進一步加強這種波動的隨機性:
            # tc qdisc add dev eth0 root netem delay 100ms 10ms 30%
            該命令將 eth0 網卡的傳輸設置為 100ms ,同時,大約有 30% 的包會延遲± 10ms發送。

             

            2. 模擬網絡丟包:
            # tc qdisc add dev eth0 root netem loss 1%
            該命令將 eth0 網卡的傳輸設置為隨機丟掉 1% 的數據包。

            也可以設置丟包的成功率:

            # tc qdisc add dev eth0 root netem loss 1% 30%
            該命令將 eth0 網卡的傳輸設置為隨機丟掉 1% 的數據包,成功率為30% 。

             

            3. 模擬包重復
            # tc qdisc add dev eth0 root netem duplicate 1%
            該命令將 eth0 網卡的傳輸設置為隨機產生1% 的重復數據包

             

            4. 模擬包損壞
            # tc qdisc add dev eth0 root netem corrupt 0.2%
            該命令將 eth0 網卡的傳輸設置為隨機產生0.2% 的損壞的數據包 。(內核版本需在2.6.16以上)

             

            5. 模擬數據包亂序
            # tc qdisc change dev eth0 root netem delay 10ms reorder 25% 50%
            該命令將 eth0 網卡的傳輸設置為:有25% 的數據包(50%相關)會被立即發送,其他的延遲10秒。

            新版本中,如下命令也會在一定程度上打亂發包的次序:

            #tc qdisc add dev eth0 root netem delay 100ms 10ms
             

            6. 刪除網卡上面的相關配置:
            將之前命令中的add 改為 del即可刪除配置:

            # tc qdisc del dev eth0 XXXXXXXXXXX(自己加的配置)
            該命令將刪除eth0網卡的相關傳輸配置

            至此,我們已經可以通過TC 在測試環境中模擬一定的網絡延時和丟包的情況。下面是關于tc更多的應用和介紹

             

            7. 查看已經配置的網絡條件
            #tc qdisc show dev eth0
            該命令將 查看并顯示eth0 網卡的相關傳輸配置

             

            8. 附錄 : TC流量控制
            在 linux中,TC有二種控制方法CBQ 和 HTB。HTB是設計用來替換CBQ 的,它是一個層次式的過濾框架。

            TC 包括三個基本的構成塊:隊列規定qdisc(queueing discipline)、類(class)和分類器(Classifiers)

            1)TC中的隊列(queueing discipline):
                    用來實現控制網絡的收發速度.通過隊列,linux可以將網絡數據包緩存起來,然后根據用戶的設置,在盡量不中斷連接(如TCP)的前提下來平滑網絡流量.需要注意的是,linux對接收隊列的控制不夠好,所以我們一般只用發送隊列,即“控發不控收”.它封裝了其他兩個主要TC 組件(類和分類器)。內核如果需要通過某個網絡接口發送數據包,它都需要按照為這個接口配置的qdisc(排隊規則)把數據包加入隊列。然后,內核會盡可能多地從qdisc里面取出數據包,把它們交給網絡適配器驅動模塊。

                    最簡單的QDisc是 pfifo,它不對進入的數據包做任何的處理,數據包采用先入先出的方式通過隊列。不過,它會保存網絡接口一時無法處理的數據包。
            隊列規則包括FIFO(先進先出),RED(隨機早期探測),SFQ(隨機公平隊列)和令牌桶(Token Bucket),類基隊列(CBQ),CBQ是一種超級隊列,即它能夠包含其它隊列(甚至其它CBQ)。

            2)TC中的Class類:
                    class用來表示控制策略.很顯然,很多時候,我們很可能要對不同的IP 實行不同的流量控制策略,這時候我們就得用不同的class來表示不同的控制策略了.

            3)TC中的Filter規則:
                    filter用來將用戶劃入到具體的控制策略中(即不同的class中).比如,現在,我們想對xxa,xxb兩個IP 實行不同的控制策略(A,B),這時,我們可用filter將 xxa 劃入到控制策略A,將xxb 劃入到控制策略B,filter劃分的標志位可用u32 打標功能或IPtables的 set-mark (大多使用iptables來做標記)功能來實現。
            目前,TC可以使用的過濾器有:fwmark分類器,u32分類器,基于路由的分類器和RSVP分類器(分別用于IPV6、IPV4)等;其中,fwmark分類器允許我們使用Linux netfilter代碼選擇流量,而u32 分類器允許我們選擇基于ANY 頭的流量.需要注意的是,filter (過濾器)是在QDisc內部,它們不能作為主體。

            4)TC 的應用流程
            數據包->iptables(在通過iptables時,iptables根據不同的ip來設置不同的 mark)->TC(class)-

            >TC(queue)

            5)TC對最對高速度的控制
            (1 Rate ceiling速率限度

                    參數 ceil 指定了一個類可以用的最大帶寬,用來限制類可以借用多少帶寬。缺省的ceil 是和速率一樣
            這個特性對于ISP 是很有用的,因為他們一般限制被服務的用戶的總量即使其他用戶沒有請求服務。(ISPS很想用戶付更多的錢得到更好的服務) ,注根類是不允許被借用的,所以沒有指定ceil。

            注: ceil的數值應該至少和它所在的類的速率一樣高,也就是說 ceil 應該至少和它的任何一個子類一樣高。

            (2 Burst 突發

                    網絡硬件只能在一個時間發送一個包這僅僅取決于一個硬件的速率。鏈路共享軟件可以利用這個能力動態產生多個連接運行在不同的速度。所以速率和ceil 不是一個即時度量只是一個在一個時間里發送包的平均值。實際的情況是怎樣使一個流量很小的類在某個時間類以最大的速率提供給其他類。 burst 和cburst參數控制多少數據可以以硬件最大的速度不費力的發送給需要的其他類。
                    如果 cburst 小于一個理論上的數據包他形成的突發不會超過ceil 速率,同樣的方法TBF 的最高速率也是這樣。
            你可能會問,為什么需要bursts 。因為它可以很容易的提高向應速度在一個很擁擠的鏈路上。比如WWW 流量是突發的。你訪問主頁。突發的獲得并閱讀。在空閑的時間burst將再"charge"一次。
            注: burst和 cburst 至少要和其子類的值一樣大。

            (3 TC命令格式:

            加入

            tc qdisc [ add | change | replace | link ] dev DEV [ parent qdisc-id | root ] [ handle qdisc-id ] qdisc[ qdisc specific parameters ]tc class [ add | change | replace ] dev DEV parent qdisc-id [ classid class-id ] qdisc [ qdisc specificparameters ]
            tc filter [ add | change | replace ] dev DEV [ parent qdisc-id | root ] protocol protocol prio priorityfiltertype [ filtertype specific parameters ] flowid flow-id
            顯示

            tc [-s | -d ] qdisc show [ dev DEV ]
            tc [-s | -d ] class show dev DEV tc filter show dev DEV
            查看TC 的狀態

            tc -s -d qdisc show dev eth0tc -s -d class show dev eth0
            刪除tc規則

            tc qdisc del dev eth0 root
            6)應用
            假設eth0 位是服務器的外網網絡接口。開始之前,先要清除eth0 所有隊列規則

            tc qdisc del dev eth0 root2> /dev/null> /dev/null
            (1 定義最頂層(根)隊列規則,并指定default類別編號

            tc qdisc add dev eth0 root handle1:htb default2
            (2 定義第一層的1:1 類別

            tc class add dev eth0 parent 1:1 classid 1:2 htb rate 98mbit ceil 100mbit prio 2
            tc class add dev eth0 parent 1:1 classid 1:3 htb rate 1mbit ceil 2mbit prio 2
            rate: 是一個類保證得到的帶寬值.如果有不只一個類,請保證所有子類總和是小于或等于父類.

            prio:用來指示借用帶寬時的競爭力,prio越小,優先級越高,競爭力越強.

            ceil: ceil 是一個類最大能得到的帶寬值.

            同時為了不使一個會話永占帶寬,添加隨即公平隊列sfq.

            tc qdisc add dev eth0 parent1:2handle 2:sfq perturb10tc qdisc
            add dev eth0 parent 1:3 handle 3: sfq perturb 10
            (3 設定過濾器

            過濾器可以使用本身的u32 也可以使用 iptables來打上標記
            指定在 root 類 1:0中,對 192..168.0.2的過濾,使用1:2 的規則,來給他98M的速度,寫法就如下

            tc filter add dev eth0 protocol ip parent 1:0 u32 match ip src
            192.168.0.2 flowid 1:2 tc filter add dev eth0 protocol ip parent1:0 u32 match ip src 192.168.0.1 flowid 1:3
            如果是所有ip 寫法就如

            tc filter add dev eth0 protocol ip parent1:prio 50u32 match ipdst 0.0.0.0/0flowid 1:10
            使用Iptables來配合過濾器,還可以使用這個方法,但需要借助下面的iptables的命令來做標記了

            tc filter add dev eth0 parent 1: protocol ip prio 1 handle 2 fw
            flowid 1:2 tc filter add dev eth0 parent 1: protocol ip prio 1handle 2 fw flowid 1:3
            iptables 只要打上記號就行了

            iptables -t mangle -A POSTROUTING -d 192.168.0.2 -j MARK --set-mark 10 iptables -t mangle -A POSTROUTING -d 192.168.0.3 -j MARK--set-mark 20
             

            posted on 2017-02-04 11:13 思月行云 閱讀(1583) 評論(0)  編輯 收藏 引用 所屬分類: 服務器\Ops
            一级女性全黄久久生活片免费 | 久久精品无码一区二区WWW| 99久久www免费人成精品| 亚洲国产二区三区久久| 合区精品久久久中文字幕一区| 国内精品伊人久久久久妇| 性做久久久久久久| 国产高清美女一级a毛片久久w| 亚洲性久久久影院| 久久精品中文闷骚内射| 久久婷婷色综合一区二区| 一本色综合网久久| 久久精品亚洲乱码伦伦中文| 色综合久久无码五十路人妻| 久久精品国产亚洲Aⅴ蜜臀色欲| 国产精品99久久久精品无码| 国内精品久久久久影院免费| 狠狠色丁香久久婷婷综合蜜芽五月| 久久99精品国产麻豆宅宅| 久久人人爽人人爽人人片av麻烦 | 久久久久亚洲AV无码专区桃色| 久久国语露脸国产精品电影| 91精品国产91久久久久久蜜臀| 99久久精品国产一区二区| 久久国产免费| 香港aa三级久久三级| 77777亚洲午夜久久多喷| 欧美黑人又粗又大久久久| 一级A毛片免费观看久久精品| 91久久成人免费| 国产精品久久久天天影视| 亚洲国产另类久久久精品小说| 日本久久中文字幕| 一级a性色生活片久久无| 一级女性全黄久久生活片免费| 久久激情亚洲精品无码?V| 久久久久亚洲AV无码去区首| 久久精品女人天堂AV麻| 日本精品久久久久影院日本| 久久久久国产亚洲AV麻豆| 久久精品视频91|