Linux中TC规则模拟丢包、延时(波动)、乱序

一、 TC可以做哪些事

作为一款功能强大的网络流量控制工具,TC可以控制网络带宽、丢包率、延时等网络参数,使我们能够在网络环境良好的局域网中模拟出各种复杂的网络场景。

二、 TC的工作原理

操作系统处理网络数据的基本流程如下:报文分组从网卡输入口处接收进来,操作系统通过查看报文目的IP,以确定是发给本机的,还是需要转发的。如果是发给本机的,就直接向上递交给上层的协议,比如TCP,如果是转发的,则会由网卡输出口发出,网络流量的控制通常就发生在此处。TC正是基于配置Linux内核流量控制,通过设置不同类型的网络接口队列,改变数据包发送的速率和优先级,从而达到流量控制的目的。因此,TC比较适用于需要对指定主机的输出流量进行控制的应用场景。

三、实例

注:TC规则会在系统重新启动后失效,因此需要将建立TC规则的命令写在shell脚本中,每次开机自动执行shell脚本,重新建立规则。

1、延时、延时波动

指定的eth0网卡上所有的包固定加了200ms延时 	  
tc qdisc add dev eth0 root netem delay 200ms
延迟波动,如下命令表示延迟为时延150ms-250ms波动
tc qdisc add dev eth0 root netem delay 200ms 50ms

2、丢包

随机丢包,如下代表随机丢包30%
tc qdisc add dev eth0 root netem loss 30%  
可用于设置50%的丢包
tc qdisc add dev eth0 root netem loss 50% 

3、乱序

乱序,如下代表50ms基准上的25%乱序
tc qdisc add dev eth0 root netem delay 50ms reorder 25%  

4、延时 + 抖动

tc设置延时为100ms,30%的包会有+/- 10ms的延时
tc qdisc add dev eth0 root netem delay 100ms 10ms 30%

5、查看队列规则

tc qdisc ls

6、删除队列规则

tc qdisc del dev eth0 root

7、官方使用介绍(更多操作方法)

http://linux-ip.net/articles/Traffic-Control-HOWTO/

你可能感兴趣的:(性能测试学习,linux,网络,服务器)