Linux qos:tc DRR qdisc 不起作用

Linux qos:tc DRR qdisc 不起作用

有 tc 队列规则 DRR(Dificite Round Robin)。

它具有与 HTB 相同的功能,但它不使用装满令牌的桶,而是为每个队列分配一些差额计数器。在发送数据包时,DC 会减少数据包大小。如果 DC 小于数据包大小,则 DC 会增加队列的量程并处理下一个队列。因此,它可以按一定比例划分传出流量,而无需知道通道宽度(这是 HTB 所必需的)。请参阅http://www.unix.com/man-page/linux/8/tc-drr/

设置:两台主机,172.16.1.1 和 172.16.1.2。

在第一个主机上我们正在监听流量:

nc -l 8111
nc -l 8112

在第二台主机上我们检查速度:

pv /dev/zero | nc 172.16.1.1 8111
pv /dev/zero | nc 172.16.1.1 8112

现在速度相等(pv 是用于测量通过管道传输数据的速度的实用程序)。在第二台主机上添加 DRR(顶部的 HTB 用于模拟实际通道速度限制):

tc qdisc add dev eth0 root handle 1: htb
tc class add dev eth0 parent 1: classid 1:1 htb rate 100mbit ceil 100mbit
tc qdisc add dev eth0 parent 1:1 handle 2: drr
tc class add dev eth0 parent 2: classid 2:1 drr quantum 600
tc class add dev eth0 parent 2: classid 2:2 drr quantum 1400
tc filter add dev eth0 parent 1: protocol ip prio 1 u32 match ip dport 8111 0xffff classid 2:1
tc filter add dev eth0 parent 1: protocol ip prio 1 u32 match ip dport 8112 0xffff classid 2:2

速度保持不变:(我做错了什么?

答案1

答案:DRR 本身不会丢弃数据包。要获得所需的行为,请将子 qdisc 添加到 DRR 子类,pfifo limit 50以使子 qdisc 丢弃数据包,而不是无限期地将它们排队。解决方案在这里找到:linux.org.ru 线程

参考:人 tc-drr

注意:此实现不会在超出限制时丢弃最长队列中的数据包,因为限制由各个子 qdiscs 处理。

答案2

drr 是一个调度程序,您仍然需要使用 htb 为类分配不同的带宽。我猜您虽然将量子指定为 600 和 1400 会给出接近 1:2 的比率。事实上不会。您可能仅在发生拥塞时在配置上接近该比率,例如创建多个 UDP 流,然后测量两个有问题的流,但这仍然不是您所期望的。

相关内容