linux tc htb 带宽上限被忽略并给出不正确的结果

linux tc htb 带宽上限被忽略并给出不正确的结果

我正在设置一些 htb 数据包队列,如下所示:

tc qdisc add dev eth0 root handle 10: htb
tc qdisc add dev eth1 root handle 10: htb

tc class add dev eth0 parent 10: classid 10:1012 htb rate 750kbps ceil 750kbps
tc filter add dev eth0 parent 10: protocol ip prio 10 handle 1: cgroup
tc class add dev eth1 parent 10: classid 10:1012 htb rate 750kbps ceil 750kbps
tc filter add dev eth1 parent 10: protocol ip prio 10 handle 1: cgroup

我正在使用 wget 下载一个 10MB 的文件来测试它。我已验证数据包上是否有正确的 classid。

当我没有使用这些 tc 规则进行下载时,我获得的平均下载速度约为 9MB/s

当我应用限制时,我的速度会下降,但会下降到错误的数字。它始终保持在 3.7MB/s 的最高速度。

我不知道为什么我的限制会超出这么多,尤其是考虑到我设置了上限。我确实注意到下载速度似乎一开始限制在 750kbps,但随后开始逐渐加快。

有人知道我做错了什么吗?

干杯!

答案1

如果不进一步了解您的实际配置,我将假设您遇到了 cgroup 问题。

尝试此操作来排除您的 cgroups 并仅限制设备本身。

#!/bin/bash

# Using ifb device to shape ingress traffic
modprobe ifb
ifconfig ifb0 up

# flush tc
tc qdisc del dev eth0 root &> /dev/null
tc qdisc del dev eth0 ingress &> /dev/null
tc qdisc del dev ifb0 root &> /dev/null

# limit all outbound traffic
tc qdisc add dev eth0 root handle 1: htb default 1
tc class add dev eth0 parent 1: classid 1:1 htb rate 1mbit

# forward inbound traffic to ifb
tc qdisc add dev eth0 ingress
tc filter add dev eth0 parent ffff: protocol all u32 match u32 0 0 action mirred egress redirect dev ifb0

# limit all inbound traffic via ifb egress
tc qdisc add dev ifb0 root handle 1: htb default 1
tc class add dev ifb0 parent 1: classid 1:1 htb rate 1mbit

测试一下,你会发现它对入站和出站都有效。如果你只想限制一个方向,那就忽略另一个方向。

相关内容