程式扎記: [Linux 文章收集] Linux 高級流量控制之netem(模擬複雜網絡環境下的傳輸性能)

標籤

2015年7月1日 星期三

[Linux 文章收集] Linux 高級流量控制之netem(模擬複雜網絡環境下的傳輸性能)

Source From Here 
一、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)也會受到影響,反之,如果您在邏輯網卡上做控制,該控制可能是無效的。(注:虛擬機中的多個網卡可以在虛擬機中視為多個物理網卡)。 

二、模擬延遲傳輸 
下面命令將 eth0 網卡的傳輸設置為延遲100毫秒發送: 
# tc qdisc add dev eth0 root netem delay 100ms

更真實的情況下,延遲值不會這麼精確,會有一定的波動,我們可以用下面的情況來模擬出帶有波動性的延遲值: 
# tc qdisc add dev eth0 root netem delay 100ms 10ms

該命令將 eth0 網卡的傳輸設置為延遲100ms ± 10ms(90 ~ 110 ms之間的任意值)發送。 

還可以更進一步加強這種波動的隨機性: 
# tc qdisc add dev eth0 root netem delay 100ms 10ms 30%

該命令將 eth0 網卡的傳輸設置為 100ms,同時,大約有 30% 的封包會延遲 ± 10ms發送。 

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

也可以設置丟包的成功率: 
# tc qdisc add dev eth0 root netem loss 1% 30%

該命令將eth0網卡的傳輸設置為隨機丟掉1%的數據包,成功率為30%。 

四、模擬包重複 
下面命令將 eth0 網卡的傳輸設置為隨機產生1%的重複數據包: 
# tc qdisc add dev eth0 root netem duplicate 1%

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

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

新版本中,如下命令也會在一定程度上打亂發包的次序: 
# tc qdisc add dev eth0 root netem delay 100ms 10ms

Supplement 
[Linux 文章收集] TC 入門 (traffic control)

沒有留言:

張貼留言

網誌存檔

關於我自己

我的相片
Where there is a will, there is a way!