linux标记数据包测时延,在Linux上模拟延迟和丢弃的数据包

2002d69e61d69446cc42052d3ef46fb6.png

慕少森

netem利用Linux和用户空间实用程序中已内置的功能来模拟网络。这实际上是Mark的答案所指的另一种名称。他们主页上的示例已经显示了如何实现您所要求的:例子模拟广域网延迟这是最简单的示例,它只是向从本地以太网传出的所有数据包增加了固定的延迟量。# tc qdisc add dev eth0 root netem delay 100ms现在,对本地网络上的主机进行的简单ping测试应该显示增加了100毫秒。延迟受内核的时钟分辨率(Hz)限制。在大多数2.4系统上,系统时钟以100 Hz运行,这允许以10 ms为增量的延迟。在2.6上,该值是1000到100 Hz之间的配置参数。后面的示例仅更改参数而无需重新加载qdisc实际的广域网显示出可变性,因此可以添加随机变化。# tc qdisc change dev eth0 root netem delay 100ms 10ms这导致增加的延迟为100±10 ms。网络延迟变化并非纯粹是随机的,因此要模拟也存在一个相关值。# tc qdisc change dev eth0 root netem delay 100ms 10ms 25%这导致添加的延迟为100±10 ms,而下一个随机元素取决于最后一个元素的25%。这不是真正的统计相关性,而是近似值。延迟分配通常,网络中的延迟不是均匀的。更常见的是使用正态分布之类的东西来描述延迟的变化。netem学科可以使用一个表来指定非均匀分布。# tc qdisc change dev eth0 root netem delay 100ms 20ms distribution normal实际的表(普通表,pareto,paretonormal)作为iproute2编译的一部分生成,并放置在/ usr / lib / tc中。因此可以根据实验数据做出自己的分配。数据包丢失在'tc'命令中以百分比指定随机数据包丢失。最小的非零值是:2 −32 = 0.0000000232%# tc qdisc change dev eth0 root netem loss 0.1%这将导致百分之一的十分之一(即千分之一)的数据包被随机丢弃。也可以添加可选的相关性。这导致随机数生成器的随机性降低,并可用于模拟数据包突发丢失。# tc qdisc change dev eth0 root netem loss 0.3% 25%这将导致0.3%的数据包丢失,并且每个连续概率取决于最后一个概率的四分之一。概率n = 0.25×概率n-1 + 0.75×随机请注意,tc qdisc add如果没有针对该接口的规则,或者tc qdisc change已经具有针对该接口的规则,则应使用。尝试tc qdisc change在没有规则的接口上使用将产生错误RTNETLINK answers: No such file or directory。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值