web-dev-qa-db-ja.com

linux tc htb帯域幅ceilが無視され、不適切な結果が表示される

私は次のようにいくつかの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のファイルをダウンロードしてテストしています。パケットに正しいクラスIDが設定されていることを確認しました。

これらのtcルールなしでダウンロードを実行すると、平均ダウンロード速度は約9MB /秒になります。

制限を適用すると、速度は低下しますが、間違った数値に低下します。それは3.7MB /秒で一貫してトップになります。

特に天井がセットされていることを考えると、なぜ私の限界がこれほどまでに超えているのかわかりません。ダウンロードは750kbpsで制限されているように見えますが、その後徐々に速度が上がり始めていることに気づきました。

誰かが私が間違っていることについて何か考えを持っていますか?

乾杯!

4
Rooster

実際の構成についてさらに知識がなければ、cgroupに問題があると想定します。

これを試して、cgroupを除外し、デバイス自体を制限してください。

#!/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

テストすると、インバウンドとアウトバウンドの両方で機能することがわかります。一方向にのみ制限したい場合は、他の部分を無視してください。

1
Ian Macintosh