Генерация джиттера с netem не работает
Я пытаюсь симулировать джиттер в моей сети с помощью netem. Я использую следующую команду:
sudo tc qdisc add dev eno3 root netem delay 200ms 100ms
И эта команда выводит пинг на другой IP:
$ ping 10.82.96.254 -c 10
PING 10.82.96.254 (10.82.96.254) 56(84) bytes of data.
64 bytes from 10.82.96.254: icmp_seq=1 ttl=255 time=258 ms
64 bytes from 10.82.96.254: icmp_seq=2 ttl=255 time=233 ms
64 bytes from 10.82.96.254: icmp_seq=3 ttl=255 time=295 ms
64 bytes from 10.82.96.254: icmp_seq=6 ttl=255 time=260 ms
64 bytes from 10.82.96.254: icmp_seq=8 ttl=255 time=212 ms
64 bytes from 10.82.96.254: icmp_seq=4 ttl=255 time=4466 ms
64 bytes from 10.82.96.254: icmp_seq=5 ttl=255 time=4474 ms
64 bytes from 10.82.96.254: icmp_seq=7 ttl=255 time=4459 ms
64 bytes from 10.82.96.254: icmp_seq=9 ttl=255 time=4476 ms
64 bytes from 10.82.96.254: icmp_seq=10 ttl=255 time=4453 ms
--- 10.82.96.254 ping statistics ---
10 packets transmitted, 10 received, 0% packet loss, time 9051ms
rtt min/avg/max/mdev = 212.173/2359.059/4476.181/2107.031 ms, pipe 5
Обычно с помощью этой команды я ожидаю, что время прохождения сигнала в обоих направлениях будет варьироваться от 100 до 300 мс, поэтому эти 4400 мс ответы меня действительно удивляют. Если я только генерирую задержку, все работает нормально:
$ ping 10.82.96.254 -c 10
PING 10.82.96.254 (10.82.96.254) 56(84) bytes of data.
64 bytes from 10.82.96.254: icmp_seq=1 ttl=255 time=202 ms
64 bytes from 10.82.96.254: icmp_seq=2 ttl=255 time=200 ms
64 bytes from 10.82.96.254: icmp_seq=3 ttl=255 time=200 ms
64 bytes from 10.82.96.254: icmp_seq=4 ttl=255 time=200 ms
64 bytes from 10.82.96.254: icmp_seq=5 ttl=255 time=202 ms
64 bytes from 10.82.96.254: icmp_seq=6 ttl=255 time=201 ms
64 bytes from 10.82.96.254: icmp_seq=7 ttl=255 time=201 ms
64 bytes from 10.82.96.254: icmp_seq=8 ttl=255 time=200 ms
64 bytes from 10.82.96.254: icmp_seq=9 ttl=255 time=200 ms
64 bytes from 10.82.96.254: icmp_seq=10 ttl=255 time=203 ms
--- 10.82.96.254 ping statistics ---
10 packets transmitted, 10 received, 0% packet loss, time 9003ms
rtt min/avg/max/mdev = 200.365/201.286/203.059/1.013 ms
Я использую образ сервера Ubuntu 18.04 со всеми современными пакетами. В 16.04 я использовал ту же утилиту для генерации сетевых искажений, и я думаю, что она работала нормально в предыдущем дистрибутиве Linux 16.04LTS, используя то же оборудование.
Небольшая деталь заключается в том, что я использую мост между eno3 и eno4 и получаю доступ к серверу Linux через eno1.
1 ответ
Это похоже на ошибку в ядре 4.15. Чтобы решить эту проблему, вам нужно обновить систему до версии 4.18 или понизить ядро Linux. Это описание проблемы в Launchpad: ссылка