linux tc htb bandwidth 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

И я тестирую его, загрузив файл размером 10 МБ с помощью wget. Я проверил, что у пакетов есть правильный classid на них.

Когда я выполняю загрузку без этих правил tc, я получаю среднюю скорость загрузки ~ 9 МБ / с.

Когда я применяю лимит, моя скорость падает, но падает до неверного значения. Он постоянно достигает 3,7 МБ / с.

Я понятия не имею, почему мой лимит переходит так сильно, особенно учитывая, что у меня установлен лимит. Я заметил, что загрузка, по-видимому, начинается на скорости 750 Кбит / с, но затем начинает постепенно набирать скорость.

У кого-нибудь есть идеи, что я делаю не так?

Ура!

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

Протестируйте, и вы должны увидеть, что он работает как входящий, так и исходящий. Если вы хотите ограничить только в одном направлении, просто игнорируйте другую часть.

Другие вопросы по тегам