Netem参数说明

本文主要内容来自Linux基金会Wiki网站Netem文档,点击这里访问原文

netem通过模拟广域网的特性为测试协议提供网络仿真功能。当前版本模拟可变延迟,丢失,重复和重新排序。

如果您运行当前的2.6发行版(FedoraOpenSuseGentooDebianMandrivaUbuntu),那么netem已在内核中启用,并且包含当前版本的iproute2。 netem内核组件在以下位置启用:

 Networking -->
Networking Options -->
QoS and/or fair queuing -->
Network emulator

Netem由命令行工具tc控制,它是iproute2工具包的一部分。 tc命令使用/usr/lib/tc目录中的共享库和数据文件。

目录

  • 模拟广域网延迟
  • 指定延迟的分布
  • 数据包丢失
  • 数据包重复
  • 数据包损坏
  • 数据包重新排序
  • HZ的值如何影响Netem?

模拟广域网延迟

这是最简单的示例,它只是为从本地以太网发出的所有数据包添加了固定数量的延迟。

delay 100ms

现在,在本地网络上进行主机的简单ping测试应显示增加100毫秒。延迟受内核(HZ)的时钟分辨率限制。在大多数内核版本为2.4的系统中,系统时钟以100hz运行,允许延迟增量为10ms。在2.6内核上,该值是1000到100赫兹的可配置参数。

真正的广域网具有可变性,因此可以添加随机变化。

delay 100ms 10ms

这导致增加的延迟为100ms±10ms。网络延迟变化不是纯粹随机的,因此要模拟存在相关性

delay 100ms 10ms 25%

这导致增加的延迟为100ms±10ms,下一个随机元素取决于最后一个随机元素的25%。这不是真正的统计学意义上的相关性,而只是程序模拟的近似值。

指定延迟的分布

通常,网络中的延迟是不均匀的。使用类似正态分布的东西来描述延迟的变化更为常见。 netem可以采用预先编写的表格来指定非均匀的分布。

delay 100ms 20ms distribution normal

实际使用的表格(normal,pareto,paretonormal)作为iproute2编译的一部分生成并放在/usr/lib/tc中;因此用户可以根据实验数据花费一点时间编写自己的分布表格。

数据包丢失

随机的数据包丢失在tc命令中以百分比形式指定。最小的非零值是:

1/(2的32次方) = 0.0000000232%

loss 0.1%

这导致0.1个百分点的(即1000个中的1个)数据包被随机丢弃。

还可以添加可选的相关性。使随机数不那么随机,可以用于模拟分组突发丢失。

loss 0.3% 25%

这将导致0.3%的数据包丢失,并且下一个包丢失的概率有四分之一取决于上一个数据包的丢包概率。

丢包概率(n) = 0.25 * 丢包概率(n-1) + 0.75 * 指定概率

数据包重复

数据包重复的指定方式与数据包丢失的方式相同。

duplicate 1%

数据包损坏

可以制造数据包损坏来模拟随机噪声(在2.6.16内核或更高版本中)。这个功能会在数据包中的随机位置引入单个比特的错误(翻转)。

corrupt 0.1%

数据包重新排序

指定数据包重新排序有两种不同的方法。第一个方法是gapgap使用固定序列并重新排序每第N个数据包。一个简单的用例是:

gap 5 delay 10ms

这会导致每隔5(10,15,...)个数据包会立即发送,其他每个数据包都会延迟10ms。这种方式模拟的重排是可预测的。

重新排序的第二种方式更贴近真实网络。它会导致一定比例的数据包被错误排序:

delay 10ms reorder 25% 50%

在此示例中,25%的数据包(相关性为50%)将立即发送,其他数据包将延迟10毫秒。

如果相邻数据包的随机延迟值不同,netem的较新版本也将重新排序数据包。以下参数将导致这一类的重新排序:

delay 100ms 75ms

如果第一个数据包的随机延迟为100毫秒(100毫秒基数 - 0毫秒抖动),第二个数据包在1毫秒后发送,延迟时间为50毫秒(100毫秒基数 - 50毫秒抖动),第二个数据包将首先发送。这是因为在netem内部的队列规则tfifo会按时间顺序进行数据包发送。

注意

  • 混合形式的重新排序可能会导致意外结果;
  • 任何方式的重新排序,都会引入延迟;
  • 如果延迟小于数据包之间到达时间的时间差,则无法观察到数据包的重新排序。

HZ的值如何影响Netem?

在2.6内核中,HZ是一个可配置参数,取值为100,250或1000。因为它会影响Netem能够延迟数据包的粒度,所以最好将HZ设置为1000,允许以1ms的增量延迟。有关HZ影响的更详细讨论,请参阅此邮件列表上的帖子。

在内核版本2.6.22或更高版本中,netem将使用高分辨率计时器(如果已启用)。这允许更精细的粒度(亚单位)分辨率。

Netem参数说明的更多相关文章

  1. 《连载 | 物联网框架ServerSuperIO教程》2.服务实例的配置参数说明

    1.C#跨平台物联网通讯框架ServerSuperIO(SSIO)介绍  <连载 | 物联网框架ServerSuperIO教程>1.4种通讯模式机制 一.综述 SuperIO(SIO)定位 ...

  2. JQuery UI dialog 弹窗实例及参数说明

    按钮代码: <a id="suprise" style="margin-left: 0.5em;cursor:pointer;">点我会有惊喜< ...

  3. 服务器.htaccess 详解以及 .htaccess 参数说明(转载)

    htaccess文件(或者”分布式配置文件”)提供了针对目录改变配置的方法, 即,在一个特定的文档目录中放置一个包含一个或多个指令的文件, 以作用于此目录及其所有子目录.作为用户,所能使用的命令受到限 ...

  4. Mongodb启动命令mongod参数说明

    Mongodb启动命令mongod参数说明 mongod的主要参数有: 基本配置 ----------------------------------------------------------- ...

  5. Connect to Database Using Custom params链接数据库配置参数说明

    使用RF的关键字Connect to Database Using Custom params链接数据库,对应的参数说明: a)     第一个参数我使用的是cx_Oracle,就写这个 b)     ...

  6. .htaccess详解及.htaccess参数说明【转】

    目录(?)[-] htaccess 详解 htaccess rewrite 规则详细说明 RewriteEngine OnOff RewriteBase URL-path RewriteCond Te ...

  7. 转载《SimpleAdapter的参数说明》

    SimpleAdapter的参数说明 第一个参数 表示访问整个android应用程序接口,基本上所有的组件都需要 第二个参数表示生成一个Map(String ,Object)列表选项 第三个参数表示界 ...

  8. Redis配置文件参数说明

    Redis配置文件参数说明   1. Redis默认不是以守护进程的方式运行,可以通过该配置项修改,使用yes启用守护进程 daemonize no 2. 当Redis以守护进程方式运行时,Redis ...

  9. mosquitto_pub和mosquitto_sub 命令参数说明

    mosquitto_pub 命令参数说明 1. -d  打印debug信息 2. -f  将指定文件的内容作为发送消息的内容 3. -h  指定要连接的域名  默认为localhost 4. -i   ...

随机推荐

  1. fiddler抓包小技巧之自动保存抓包数据(可根据需求过滤)

    首先 选择 如果有别的提示的话,你就按着提示走,就会安装一个编辑器,叫Fiddler Script. 正常情况下,你按着上面操作之后就会出现如下界面: 完事了之后,按下Ctrl+F来查找OnBefor ...

  2. jQuery获取当前按钮的id

    function test(e) { $(e.target).attr('id') } // 记得带上点击事件

  3. 跟着动画来学习TCP三次握手和四次挥手

    TCP三次握手和四次挥手的问题在面试中是最为常见的考点之一.很多读者都知道三次和四次,但是如果问深入一点,他们往往都无法作出准确回答. 点我查看如何应对面试中的三次握手.四次挥手 本篇尝试使用动画来对 ...

  4. 【LOJ 6695】天气之子

    找规律题的典范? OEIS裸题 考场上让你用 OEIS 吗 题意 link 题解 \(n\le 5\) 打表 \(n\le 10^5\) 发现不能直接求最优解,于是二分答案. 验证答案时,先把前 \( ...

  5. k8spod探测

    一.pod存活性探测 pod spec为容器列表中的相应容器定义其专用的探针即可启用存活性探测,目前,k8s的容器支持存活性探测的方法包含:ExecAction.TCPSocketActon和HTTP ...

  6. 基于django中settings中间件源码思想,实现功能的插拔式设计

    这里我们用到一个非常重要的模块,importlib,利用它可以实现字符串转python代码,再利用反射进行操作,这样就可以实现插拔式设计. 一.我们先做个初级的,把所有文件放到初级思想文件夹下: 1. ...

  7. python时间 time模块和datetime模块

    一.time模块 time模块中时间表现的格式主要有三种: a.timestamp时间戳,时间戳表示的是从1970年1月1日00:00:00开始按秒计算的偏移量 b.struct_time时间元组,共 ...

  8. 【Linux学习一】命令行CLI、BASH的基本操作

    ●操作系统的基本结构 操作系统的基本结构通过Kernel(内核)和Shell(壳)构成.常见的Shell分为GUI和CLI GUI 图形方面的shell ------〉windows .mac osC ...

  9. Python网络爬虫_爬取Ajax动态加载和翻页时url不变的网页

    1 . 什么是 AJAX ? AJAX = 异步 JavaScript 和 XML. AJAX 是一种用于创建快速动态网页的技术. 通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新 ...

  10. linux运维、架构之路-Kubernetes离线集群部署-无坑

    一.部署环境介绍 1.服务器规划 系统 IP地址 主机名 CPU 内存 CentOS  7.5 192.168.56.11 k8s-node1 2C 2G CentOS  7.5 192.168.56 ...