Mam skrzynkę linux, której używam jako iperf3
klienta, testując 2 identycznie wyposażone skrzynki serwera Windows 2012 R2 z adapterami Broadcom BCM5721, 1 Gb (2 porty, ale tylko 1 używany do testu). Wszystkie maszyny są podłączone za pomocą jednego przełącznika 1 Gb.
Testowanie UDP przy np. 300 Mb
iperf3 -uZVc 192.168.30.161 -b300m -t5 --get-server-output -l8192
powoduje utratę 14% wszystkich wysłanych pakietów (dla drugiego serwera z tym samym sprzętem, ale starszymi sterownikami NIC, utrata wynosi około 2%), ale utrata występuje nawet przy 50 Mb, choć mniej poważnie. Wydajność TCP przy użyciu równoważnych ustawień:
iperf3 -ZVc 192.168.30.161 -t5 --get-server-output -l8192
zapewnia prędkości transmisji na północ od 800Mbit, bez zgłaszanych retransmisji.
Serwer jest zawsze uruchamiany przy użyciu następujących opcji:
iperf3 -sB192.168.30.161
Kto jest winny?
Klient Linuksa (sprzęt? Sterowniki? Ustawienia?)?Edycja: Właśnie uruchomiłem test z jednego serwera Windows do drugiego, a utrata pakietów UDP przy 300 Mb była jeszcze wyższa, o 22%- Okna serwera Windows (sprzęt? Sterownik? Ustawienia?)?
- (Pojedynczy) przełącznik, który łączy wszystkie maszyny testowe?
- Kable?
Edytować:
Teraz spróbowałem w innym kierunku: Windows -> Linux. Wynik: utrata pakietów zawsze wynosi 0 , podczas gdy przepustowość osiąga maksymalny poziom około
- 840 Mb dla
-l8192
np. Pofragmentowanych pakietów IP - 250 Mb dla
-l1472
niefragmentowanych pakietów IP
Wydaje mi się, że przepustowość ogranicza kontrolę przepływu i zapobiega utracie pakietów. Zwłaszcza ta ostatnia, niefragmentowana liczba nie jest zbliżona do przepustowości TCP (niefragmentowany TCP daje podobne liczby do fragmentowanego TCP), ale jest to nieskończenie ogromna poprawa w stosunku do Linuksa -> Windows pod względem utraty pakietów.
I jak się dowiedzieć?
Postępowałem zgodnie ze zwykłymi zaleceniami dotyczącymi ustawień sterownika na serwerze, aby zmaksymalizować wydajność i próbowałem włączyć / wyłączyć / zmaksymalizować / zminimalizować / zmienić
- Przerwanie moderacji
- Kontrola przepływu
- Buforów odbiorczych
- RSS
- Wake-on-LAN
Wszystkie funkcje odciążania są włączone.
Edytuj Próbowałem także włączyć / wyłączyć
- Ethernet @ Wirespeed
- Różne funkcje odciążania
- Priorytet i sieć VLAN
Przy podobnych wskaźnikach strat.
Pełny wynik uruchomienia UDP:
$ iperf3 -uZVc 192.168.30.161 -b300m -t5 --get-server-output -l8192
iperf 3.0.7
Linux mybox 3.16.0-4-amd64 #1 SMP Debian 3.16.7-ckt4-3 (2015-02-03) x86_64 GNU/Linux
Time: Wed, 13 May 2015 13:10:39 GMT
Connecting to host 192.168.30.161, port 5201
Cookie: mybox.1431522639.098587.3451f174
[ 4] local 192.168.30.202 port 50851 connected to 192.168.30.161 port 5201
Starting Test: protocol: UDP, 1 streams, 8192 byte blocks, omitting 0 seconds, 5 second test
[ ID] Interval Transfer Bandwidth Total Datagrams
[ 4] 0.00-1.00 sec 33.3 MBytes 279 Mbits/sec 4262
[ 4] 1.00-2.00 sec 35.8 MBytes 300 Mbits/sec 4577
[ 4] 2.00-3.00 sec 35.8 MBytes 300 Mbits/sec 4578
[ 4] 3.00-4.00 sec 35.8 MBytes 300 Mbits/sec 4578
[ 4] 4.00-5.00 sec 35.8 MBytes 300 Mbits/sec 4577
- - - - - - - - - - - - - - - - - - - - - - - - -
Test Complete. Summary Results:
[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams
[ 4] 0.00-5.00 sec 176 MBytes 296 Mbits/sec 0.053 ms 3216/22571 (14%)
[ 4] Sent 22571 datagrams
CPU Utilization: local/sender 4.7% (0.4%u/4.3%s), remote/receiver 1.7% (0.8%u/0.9%s)
Server output:
-----------------------------------------------------------
Accepted connection from 192.168.30.202, port 44770
[ 5] local 192.168.30.161 port 5201 connected to 192.168.30.202 port 50851
[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams
[ 5] 0.00-1.01 sec 27.2 MBytes 226 Mbits/sec 0.043 ms 781/4261 (18%)
[ 5] 1.01-2.01 sec 30.0 MBytes 252 Mbits/sec 0.058 ms 734/4577 (16%)
[ 5] 2.01-3.01 sec 29.0 MBytes 243 Mbits/sec 0.045 ms 870/4578 (19%)
[ 5] 3.01-4.01 sec 32.1 MBytes 269 Mbits/sec 0.037 ms 469/4579 (10%)
[ 5] 4.01-5.01 sec 32.9 MBytes 276 Mbits/sec 0.053 ms 362/4576 (7.9%)
Uruchom TCP:
$ iperf3 -ZVc 192.168.30.161 -t5 --get-server-output -l8192
iperf 3.0.7
Linux mybox 3.16.0-4-amd64 #1 SMP Debian 3.16.7-ckt4-3 (2015-02-03) x86_64 GNU/Linux
Time: Wed, 13 May 2015 13:13:53 GMT
Connecting to host 192.168.30.161, port 5201
Cookie: mybox.1431522833.505583.4078fcc1
TCP MSS: 1448 (default)
[ 4] local 192.168.30.202 port 44782 connected to 192.168.30.161 port 5201
Starting Test: protocol: TCP, 1 streams, 8192 byte blocks, omitting 0 seconds, 5 second test
[ ID] Interval Transfer Bandwidth Retr Cwnd
[ 4] 0.00-1.00 sec 109 MBytes 910 Mbits/sec 0 91.9 KBytes
[ 4] 1.00-2.00 sec 97.3 MBytes 816 Mbits/sec 0 91.9 KBytes
[ 4] 2.00-3.00 sec 97.5 MBytes 818 Mbits/sec 0 91.9 KBytes
[ 4] 3.00-4.00 sec 98.0 MBytes 822 Mbits/sec 0 91.9 KBytes
[ 4] 4.00-5.00 sec 97.6 MBytes 819 Mbits/sec 0 91.9 KBytes
- - - - - - - - - - - - - - - - - - - - - - - - -
Test Complete. Summary Results:
[ ID] Interval Transfer Bandwidth Retr
[ 4] 0.00-5.00 sec 499 MBytes 837 Mbits/sec 0 sender
[ 4] 0.00-5.00 sec 498 MBytes 836 Mbits/sec receiver
CPU Utilization: local/sender 3.5% (0.5%u/3.0%s), remote/receiver 4.5% (2.0%u/2.5%s)
Server output:
-----------------------------------------------------------
Accepted connection from 192.168.30.202, port 44781
[ 5] local 192.168.30.161 port 5201 connected to 192.168.30.202 port 44782
[ ID] Interval Transfer Bandwidth
[ 5] 0.00-1.00 sec 105 MBytes 878 Mbits/sec
[ 5] 1.00-2.00 sec 97.5 MBytes 818 Mbits/sec
[ 5] 2.00-3.00 sec 97.6 MBytes 819 Mbits/sec
[ 5] 3.00-4.00 sec 97.8 MBytes 820 Mbits/sec
[ 5] 4.00-5.00 sec 97.7 MBytes 820 Mbits/sec
źródło
-l
robi przełącznik. Nie ustawia rozmiaru bufora; ustawia rozmiar pakietu. Jest to ilość danych, które iperf3 zapisze w gnieździe za jednym razem i odczyta z gniazda za jednym razem. Możesz ustawić rozmiar bufora gniazda za pomocą-w
. Jeśli spojrzysz na źródło, zobaczysz, że wywołuje,setsockopt()
aby ustawić rozmiar bufora gniazda na cokolwiek podałeś po-w
.Całkowicie przegapiłeś najbardziej oczywistego winowajcę - adaptery, a następnie sterowniki (stwierdzasz, że użycie innej wersji sterowników daje inne wyniki).
Spróbuj wyłączyć wszystkie funkcje odciążania.
źródło