linux 下使用 tc 模拟网络延迟和丢包
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)也会受到影响,反之,如果您在逻辑网卡上做控制,该控制可能是无效的。(注:虚拟机中的多个网卡可以在虚拟机中视为多个物理网卡)。
# tc qdisc add dev eth0 root netem delay 100ms
该命令将
eth0
网卡的传输设置为延迟
100 毫秒发送。易宝支付有限公司
更真实的情况下,延迟值不会这么精确,会有一定的波动,我们可以用下面的情况来模拟出
带有波动性的延迟值:
# 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 发送。示例:现在 ping 一下 216 机器:
易宝支付有限公司
可以看出数据明显的波动性。
3 模拟网络丢包:
# tc qdisc add dev eth0 root netem loss 1%
该命令将
eth0
网卡的传输设置为随机丢掉
1% 的数据包。示例:在
216
上执行
#tc qdisc add dev eth0 root netem loss 10%
显示 16
个包只有
13 个收到了。也可以设置丢包的成功率:
# tc qdisc add dev eth0 root netem loss 1% 30%
该命令将
eth0
网卡的传输设置为随机丢掉
1% 的数据包,成功率为
30%
。
4.删除网卡上面的相关配置:将之前命令中的
add
改为 del
即可删除配置:
# tc qdisc del dev eth0 XXXXXXXXXXX(自己加的配置)该命令将
删除 eth0
网卡的相关传输配置
至此,我们已经可以通过
TC
在测试环境中模拟一定的网络延时和丢包的情况。下面是关于tc
更多的应用和介绍
5
模拟包重复:
# tc qdisc add dev eth0 root netem duplicate 1%
该命令将
eth0
网卡的传输设置为随机产生
1%
的重复数据包 。6
模拟数据包损坏:
# tc qdisc add dev eth0 root netem corrupt 0.2%
该命令将
eth0
网卡的传输设置为随机产生
0.2%
的损坏的数据包 。
(内核版本需在
2.6.16
以上)
7
模拟数据包乱序:
# 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
8 查看已经配置的网络条件:#
tc qdisc show dev eth0
该命令将
查看并显示
eth0
网卡的相关传输配置9
附录:TC
流量控制
TC
是一个流量控制的工具,下面转了一篇关于
TC
流量控制的文章。TC
介绍
在 linux
中,TC
有二种控制方法
CBQ
和 HTB.HTB
是设计用来替换
CBQ
的。它是一个层次式的过滤框架.
TC
包括三个基本的构成块:
队列规定
qdisc(queueing discipline
)、类(class)和分类器(Classifiers)
TC
中的队列(queueing discipline):
用来实现控制网络的收发速度.通过队列,linux
可以将网络数据包缓存起来,然后根据用户的
设置,在尽量不中断连接(如
TCP)的前提下来平滑网络流量.需要注意的是,linux
对接收队列的控制不够好,所以我们一般只用发送队列,即“控发不控收”.它封装了其他两个主要
TC
组件(类和分类器)。内核如果需要通过某个网络接口发送数据包,它都需要按照为这个接口配置的
qdisc(排队规则)把数据包加入队列。然后,内核会
尽可能多地从
qdisc
里面取出数据包,把它们交给网络适配器驱动模块。
最简单的
QDisc
是
pfifo
它不对进入的数据包做任何的处理,数据包采用先入先出的方式通过队列。不过,它会保存网络接口一时无法处理的数据包。
队列规则包括
FIFO(先进先出),RED(随机早期探测),SFQ(随机公平队列)和令牌桶(Token
Bucket),类基队列(CBQ),CBQ
是一种超级队列,即它能够包含其它队列(甚至其它
CBQ)。
TC
中的
Class
类
class
用来表示控制策略.很显然,很多时候,我们很可能要对不同的
IP
实行不同的流量控制策略,这时候我们就得用不同的
class
来表示不同的控制策略了.
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
内部,它们不能作为主体。
TC
的应用流程
数据包->iptables(在通过
iptables
时,iptables
根据不同的
ip
来设置不同的 mark)->TC(class)-
>TC(queue)
应用
假设
eth0
位是服务器的外网网络接口。开始之前,先要清除
eth0
所有队列规则
tc qdisc del dev eth0 root
2> /dev/null
> /dev/null1)
定义最顶层(根)队列规则,并指定
default
类别编号
tc qdisc add dev eth0 root handle
1:
htb default
2易宝支付有限公司
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
注:以上就是我们控制输出服务器的速度,一个为 98M,一个为 2M.
rate: 是一个类保证得到的带宽值.如果有不只一个类,请保证所有子类总和是小于或等于父类.prio:用来指示借用带宽时的竞争力,prio
越小,优先级越高,竞争力越强.
ceil: ceil 是一个类最大能得到的带宽值.
同时为了不使一个会话永占带宽,添加随即公平队列
sfq.
tc qdisc add dev eth0 parent
1:2
handle
2:
sfq perturb
10
tc 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 parent
1:0 u32 match ip src 192.168.0.1 flowid 1:3
如果是所有 ip 写法就如
tc filter add dev eth0 protocol ip parent
1:
prio
50
u32 match ip
dst 0.0.0.0/0
flowid
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 1
handle 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
TC 对最对高速度的控制
Rate ceiling
速率限度
参数
ceil
指定了一个类可以用的最大带宽,
用来限制类可以借用多少带宽.缺省的
ceil
是和速率一样
这个特性对于
ISP
是很有用的,
因为他们一般限制被服务的用户的总量即使其他用户没有请求服务.(ISPS
很想用户付更多的钱得到更好的服务)
,注根类是不允许被借用的,
所以没有指定
ceil
易宝支付有限公司
注: ceil
的数值应该至少和它所在的类的速率一样高,
也就是说
ceil
应该至少和它的任何一个子类一样高
Burst
突发
网络硬件只能在一个时间发送一个包这仅仅取决于一个硬件的速率.
链路共享软件可以利用这个能力动态产生多个连接运行在不同的速度.
所以速率和
ceil
不是一个即时度量只是一个在一个时间里发送包的平均值.
实际的情况是怎样使一个流量很小的类在某个时间类以最大的速率提供给其他类.
burst 和
cburst
参数控制多少数据可以以硬件最大的速度不费力的发送给需要的其他类.
如果
cburst
小于一个理论上的数据包他形成的突发不会超过
ceil
速率,
同样的方法
TBF
的最高速率也是这样.
你可能会问,
为什么需要
bursts .
因为它可以很容易的提高向应速度在一个很拥挤的链路上.比如
WWW
流量是突发的.
你访问主页.
突发的获得并阅读.
在空闲的时间
burst
将再"charge"一次.
注: burst
和
cburst
至少要和其子类的值一样大.
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
实例
使用 TC
下载限制单个
IP
进行速度控制
tc qdisc add dev eth0 root handle 1: htb r2q 1 tc class add dev
eth0 parent 1: classid 1:1 htb rate 30mbit ceil 60mbit tc filter
add dev eth0 parent 1: protocol ip prio 16 u32 match ip dst
192.168.1.2 flowid 1:1
就可以限制 192.168.1.2 的下载速度为 30Mbit 最高可以 60Mbit ,其中 r2q,是指没有 default 的root,使整个网络的带宽没有限制
使用 TC 对整段 IP 进行速度控制
tc qdisc add dev eth0 root handle
1:
htb r2q
1
tc class add dev
易宝支付有限公司
eth0 parent 1: classid 1:1 htb rate 50mbit ceil 1000mbit tc filter
add dev eth0 parent 1: protocol ip prio 16 u32 match ip dst
192.168.111.0/24 flowid 1:1
就可以限制 192.168.111.0 到 255 的带宽为 3000k 了,实际下载速度为 200k 左右。这种情况下,这个网段所有机器共享这 200k 的带宽。
还可以加入一个
sfq(随机公平队列)
tc qdisc add dev eth0 root handle 1: htb r2q 1 tc class add dev
eth0 parent 1: classid 1:1 htb rate 3000kbit burst 10k tc qdisc
add dev eth0 parent 1:1 handle 10: sfq perturb 10 tc filter add
dev eth0 parent 1: protocol ip prio 16 u32 match ip dst
192.168.111.168 flowid 1:1
sfq,他可以防止一个段内的一个 ip 占用整个带宽。使用 TC 控制服务器对外的速度为 10M
如下,我要管理一台服务器,只能向外发 10M 的数据
tc qdisc del dev eth0 root tc qdisc add dev eth0 root handle 1:htb tc class add dev eth0 parent 1: classid 1:1 htb rate 100mbitceil 100mbit tc class add dev eth0 parent 1:1 classid 1:10 htbrate 10mbit ceil 10mbit tc qdisc add dev eth0 parent 1:10 sfqperturb 10 tc filter add dev eth0 protocol ip parent 1: prio 2u32 match ip dst 220.181.xxx.xx/32 flowid 1:1 # 上面这台,让220.181.xxx.xx/32 这台跑默认的,主要是为了让这个 ip 连接进来不被控制 tcfilter add dev eth0 protocol ip parent 1: prio 50 u32 match ip dst0.0.0.0/0 flowid 1:10 # 默认让所有的流量都从这个通过
转自: http://blog.csdn.net/weiweicao0429/article/details/17578011
linux 下使用 tc 模拟网络延迟和丢包的更多相关文章
- linux 下使用 tc 模拟网络延迟和丢包-使用 linux 模拟广域网延迟 - Emulating wide area network delays with Linux
tc 是linux 内置的命令:使用man pages 查看 我们看到,其功能为 show / manipulate traffic control settings,可对操作系统进行流量控制: ne ...
- linux 下使用 tc 模拟网络延迟和丢包(转)
1 模拟延迟传输简介 netem 与 tc: netem 是 Linux 2.6 及以上内核版本提供的一个网络模拟功能模块.该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带 ...
- linux下使用tc(Traffic Control) 流量控制命令模拟网络延迟和丢包
目录 TC案例 TC常用命令 TC安装 TC原理介绍 TC规则 TC操作原理 TC命名规则 TC单位 TC命令 TC案例 如何使用tc模拟网络延迟和丢包 修改网络延时: sudo tc qdisc ...
- Linux模拟网络延迟、丢包等
一.工具介绍 1.netem netem 是 Linux 2.6 及以上内核版本提供的一个网络模拟功能模块.该功能模块可以用来在性能良好的局域网中,模拟出复杂的互联网传输性能,诸如低带宽.传输延迟.丢 ...
- [UE4]模拟网络延迟和丢包
进入游戏界面,按下键盘的“~”键,打开控制台界面,输入net会自动列出跟网络相关的命令 1.Net pktLag=,模拟延迟,单位是毫秒 2.Net PktLagVariance=300,在模拟延迟的 ...
- 收集TCP端口的访问延迟和丢包率
需求: 找一款工具可以对TCP 80端口 收集 访问延迟和丢包率 找到的工具: 1.Hping : http://www.hping.org/ 2.paping : https://docs.azu ...
- 【java】 linux下利用nohup后台运行jar文件包程序
Linux 运行jar包命令如下: 方式一: java -jar XXX.jar 特点:当前ssh窗口被锁定,可按CTRL + C打断程序运行,或直接关闭窗口,程序退出 那如何让窗口不锁定? 方式二 ...
- Linux下打包压缩war和解压war包
Linux下打包压缩war和解压war包 unzip是一种方法,如果不行则采用下面的方法 把当前目录下的所有文件打包成game.war jar -cvfM0 game.war ./ -c 创建wa ...
- windows下模拟网络延时、丢包、抖动
1.Fiddler 免费软件 模拟网速功能比较单一(Rules --> Performance --> Simulate Modem speed),选项较少,Fiddler仅是减缓带宽并未 ...
随机推荐
- Android开发学习之路--RxAndroid之初体验
学了一段时间android,看了部分的项目代码,然后想想老是学基础也够枯燥乏味的,那么就来学习学习新东西吧,相信很多学java的都听说过RxJava,那么android下也有RxAndroid. Rx ...
- EBS财务模块表结构
gl_code_combinations:科目组合 字段名 含义 备注 code_combination_id 主键,科目编码ID,自动编号 segment1 分行代码 setgment2 是受 ...
- iOS开发关于适配iOS10以及Xcode8的相关新知识
一.证书管理 用Xcode8打开工程后,比较明显的就是下图了,这个是苹果的新特性,可以帮助我们自动管理证书.建议大家勾选这个Automatically manage signing(Ps.但是在bea ...
- Docker教程:dokcer machine的概念和安装
http://blog.csdn.net/pipisorry/article/details/50920982 Docker machine介绍 做为Docker容器集群管理三剑客之一的Docker ...
- Sqoop执行mysql删除语句
如果使用Sqoop删除mysql中的数据,并且传递动态日期参数,则使用下方的方法: 创建一个sh文件,内容如下: #!/bin/sh ## 环境变量生效 . /etc/profile #[调度删除导入 ...
- 【Unity技巧】LOGO闪光效果
写在前面 本文参考了风宇冲的博文,在按照这篇博文实现LOGO闪光时,发现了一些问题.最严重的就是背景无法透明,看上去背景始终是黑色的:其次就是各个变量的意义不是非常明确,调节起来不方便:而且在闪光条的 ...
- Cocos2D中屏幕分辨率解释
Cocos2D的坐标(0,0)点在屏幕的左下角,然后x和y的坐标值像右上角逐渐增加. 因为项目一般是横屏(landscape)模式,这表示右上角坐标在3.5寸屏上为(480,320), 在4寸屏上为( ...
- 【一天一道LeetCode】#82. Remove Duplicates from Sorted List II
一天一道LeetCode 本系列文章已全部上传至我的github,地址:ZeeCoder's Github 欢迎大家关注我的新浪微博,我的新浪微博 欢迎转载,转载请注明出处 (一)题目 Given a ...
- (NO.00002)iOS游戏精灵战争雏形(六)
接下来我们给MainScene场景再添加一个精灵,作为敌人. 双击SpriteBuilder中的MainScene.ccb,从控件库拖入一个CCSprite到CCPhysicsNode中,设置精灵帧为 ...
- (二十七)QQ好友列表的实现
QQ好友列表通过plist读取,plist的结构为一组字典,每个字典内有本组的信息和另外一组字典代表好友. 要读取plist,选择合适的数据结构,例如NSArray,然后调用initWithConte ...