有 tc 队列规则 DRR(Dificite Round Robin) 。
它具有与 HTB 相同的功能,但不使用填充令牌的桶,它只是为每个队列分配一些 Dificit Counter。在数据包发送 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
Run Code Online (Sandbox Code Playgroud)
在第二台主机上,我们检查速度:
pv /dev/zero | nc 172.16.1.1 8111
pv /dev/zero | nc 172.16.1.1 8112
Run Code Online (Sandbox Code Playgroud)
现在速度是相等的(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
Run Code Online (Sandbox Code Playgroud)
速度保持不变:(我做错了什么?
答:DRR 本身不会丢弃数据包。为了获得所需的行为,将子 qdisc 添加到 DRR 子类中,例如pfifo limit 50
导致子 qdisc 丢弃数据包,而不是无限期地将它们有效地排队。解决方案在这里找到:linux.org.ru thread
参考:man tc-drr
注意 此实现不会在溢出时从最长队列中丢弃数据包,因为限制由各个子 qdisc 处理。
归档时间: |
|
查看次数: |
1281 次 |
最近记录: |