Our standard "make check" includes a number of benchmarks, which take quite a long time to run. This series makes a number of improvements to how we run these, which reduces wasted time and reduces the full run time by some 10-12 minutes. David Gibson (8): test/perf: Remove stale iperf3c/iperf3s directives test/perf: Get iperf3 stats from client side test/perf: Start iperf3 server less often test/perf: Small MTUs for spliced TCP aren't interesting test/perf: Explicitly control UDP packet length, instead of MTU test/perf: "MTU" changes in passt_tcp host to guest aren't useful test/perf: Remove unnecessary --pacing-timer options test/perf: Simplify calculation of "omit" time for TCP throughput .gitignore | 2 +- test/lib/test | 83 ++++++++++++++++----------- test/perf/passt_tcp | 84 +++++++++++++-------------- test/perf/passt_udp | 86 +++++++++++++--------------- test/perf/pasta_tcp | 125 ++++++++++++++++------------------------ test/perf/pasta_udp | 136 ++++++++++++++++++++++++++------------------ 6 files changed, 260 insertions(+), 256 deletions(-) -- 2.41.0
Some older revisions used separate iperf3c and iperf3s test directives to invoke the iperf3 client and server. Those were combined into a single iperf3 directive some time ago, but a couple of places still have the old syntax. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/pasta_tcp | 3 +-- test/perf/pasta_udp | 4 ---- 2 files changed, 1 insertion(+), 6 deletions(-) diff --git a/test/perf/pasta_tcp b/test/perf/pasta_tcp index 4b13384..9e9dc37 100644 --- a/test/perf/pasta_tcp +++ b/test/perf/pasta_tcp @@ -43,8 +43,7 @@ ns ip link set dev lo mtu 1500 iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 4000 -iperf3c ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -iperf3s BW host 100${i}3 __THREADS__ +iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 16384 iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ diff --git a/test/perf/pasta_udp b/test/perf/pasta_udp index 7007b6f..3de73a0 100644 --- a/test/perf/pasta_udp +++ b/test/perf/pasta_udp @@ -84,8 +84,6 @@ tr UDP throughput over IPv6: host to ns bw - bw - bw - -#iperf3c host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -#iperf3s BW ns 100${i}2 __THREADS__ iperf3 BW host ns ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 @@ -103,8 +101,6 @@ tr UDP throughput over IPv4: host to ns bw - bw - bw - -#iperf3c host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -#iperf3s BW ns 100${i}2 __THREADS__ iperf3 BW host ns 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 -- 2.41.0
iperf3 generates statistics about its run on both the client and server sides. They don't have exactly the same information, but both have the pieces we need (AFAICT the server communicates some nformation to the client over the control socket, so the most important information is in the client side output, even if measured by the server). Currently we use the server side information for our measurements. Using the client side information has several advantages though: * We can directly wait for the client to complete and we know we'll have the output we want. We don't need to sleep to give the server time to write out the results. * That in turn means we can wrap up as soon as the client is done, we don't need to wait overlong to make sure everything is finished. * The slightly different organisation of the data in the client output means that we always want the same json value, rather than requiring slightly different onces for UDP and TCP. The fact that we avoid some extra delays speeds up the overal run of the perf tests by around 7 minutes (out of around 35 minutes) on my laptop. The fact that we no longer unconditionally kill client and server after a certain time means that the client could run indefinitely if the server doesn't respond. We mitigate that by setting 1s connect timeout on the client. This isn't foolproof - if we get an initial response, but then lose connectivity this could still run indefinitely, however it does cover by far the most likely failure cases. --snd-timeout would provide more robustness, but I've hit odd failures when trying to use it. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- .gitignore | 2 +- test/lib/test | 32 ++++++++++++++------------------ 2 files changed, 15 insertions(+), 19 deletions(-) diff --git a/.gitignore b/.gitignore index d3d0e2c..d1c8be9 100644 --- a/.gitignore +++ b/.gitignore @@ -6,5 +6,5 @@ /qrap /pasta.1 /seccomp.h -/s*.json +/c*.json README.plain.md diff --git a/test/lib/test b/test/lib/test index 115dd21..3ca5dbc 100755 --- a/test/lib/test +++ b/test/lib/test @@ -31,41 +31,37 @@ test_iperf3() { __procs="$((${1} - 1))"; shift __time="${1}"; shift - pane_or_context_run "${__sctx}" 'rm -f s*.json' + pane_or_context_run "${__cctx}" 'rm -f c*.json' pane_or_context_run_bg "${__sctx}" \ 'for i in $(seq 0 '${__procs}'); do' \ - ' (iperf3 -s1J -p'${__port}' -i'${__time} \ - ' > s${i}.json) &' \ - ' echo $! > s${i}.pid &' \ + ' (iperf3 -s1 -p'${__port}' -i'${__time}') &' \ + ' echo $! > s${i}.pid; ' \ 'done' \ sleep 1 # Wait for server to be ready - pane_or_context_run_bg "${__cctx}" \ + # A 1s wait for connection on what's basically a local link + # indicates something is pretty wrong + __timeout=1000 + pane_or_context_run "${__cctx}" \ '(' \ ' for i in $(seq 0 '${__procs}'); do' \ - ' iperf3 -c '${__dest}' -p '${__port} \ - ' -t'${__time}' -i0 -T s${i} '"${@}"' &' \ + ' iperf3 -J -c '${__dest}' -p '${__port} \ + ' --connect-timeout '${__timeout} \ + ' -t'${__time}' -i0 -T c${i} '"${@}" \ + ' > c${i}.json &' \ ' done;' \ ' wait' \ ')' - sleep $((__time + 5)) - - # If client fails to deliver control message, tell server we're done + # Kill the server, just in case -1 didn't work right pane_or_context_run "${__sctx}" 'kill -INT $(cat s*.pid); rm s*.pid' - sleep 1 # ...and wait for output to be flushed - __jval=".end.sum_received.bits_per_second" - for __opt in ${@}; do - # UDP test - [ "${__opt}" = "-u" ] && __jval=".intervals[0].sum.bits_per_second" - done - __bw=$(pane_or_context_output "${__sctx}" \ - 'cat s*.json | jq -rMs "map('${__jval}') | add"') + __bw=$(pane_or_context_output "${__cctx}" \ + 'cat c*.json | jq -rMs "map('${__jval}') | add"') TEST_ONE_subs="$(list_add_pair "${TEST_ONE_subs}" "__${__var}__" "${__bw}" )" -- 2.41.0
Currently we start both the iperf3 server(s) and client(s) afresh each time we want to make a bandwidth measurement. That's not really necessary as usually a whole batch of bandwidth measurements can use the same server. Split up the iperf3 directive into 3 directives: iperf3s to start the server, iperf3 to make a measurement and iperf3k to kill the server, so that we can start the server less often. This - and more importantly, the reduced number of waits for the server to be ready - reduces runtime of the performance tests on my laptop by about 4m (out of ~28minutes). For now we still restart the server between IPv4 and IPv6 tests. That's because in some cases the latency measurements we make in between use the same ports. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/lib/test | 57 ++++++++++++++++++++++----------- test/perf/passt_tcp | 59 ++++++++++++++++++++-------------- test/perf/passt_udp | 57 ++++++++++++++++++++------------- test/perf/pasta_tcp | 77 ++++++++++++++++++++++++++++++--------------- test/perf/pasta_udp | 72 +++++++++++++++++++++++++++++------------- 5 files changed, 213 insertions(+), 109 deletions(-) diff --git a/test/lib/test b/test/lib/test index 3ca5dbc..1d571c3 100755 --- a/test/lib/test +++ b/test/lib/test @@ -13,19 +13,45 @@ # Copyright (c) 2021 Red Hat GmbH # Author: Stefano Brivio <sbrivio(a)redhat.com> +# test_iperf3s() - Start iperf3 server +# $1: Destination/server context +# $2: Port number, ${i} is translated to process index +# $3: Number of processes to run in parallel +test_iperf3s() { + __sctx="${1}" + __port="${2}" + __procs="$((${3} - 1))" + + pane_or_context_run_bg "${__sctx}" \ + 'for i in $(seq 0 '${__procs}'); do' \ + ' iperf3 -s -p'${__port}' &' \ + ' echo $! > s${i}.pid; ' \ + 'done' \ + + sleep 1 # Wait for server to be ready +} + +# test_iperf3k() - Kill iperf3 server +# $1: Destination/server context +test_iperf3k() { + __sctx="${1}" + + pane_or_context_run "${__sctx}" 'kill -INT $(cat s*.pid); rm s*.pid' + + sleep 3 # Wait for kernel to free up ports +} + # test_iperf3() - Ugly helper for iperf3 directive # $1: Variable name: to put the measure bandwidth into # $2: Source/client context -# $3: Destination/server context -# $4: Destination name or address for client -# $5: Port number, ${i} is translated to process index -# $6: Number of processes to run in parallel -# $7: Run time, in seconds +# $3: Destination name or address for client +# $4: Port number, ${i} is translated to process index +# $5: Number of processes to run in parallel +# $6: Run time, in seconds # $@: Client options test_iperf3() { __var="${1}"; shift __cctx="${1}"; shift - __sctx="${1}"; shift __dest="${1}"; shift __port="${1}"; shift __procs="$((${1} - 1))"; shift @@ -33,14 +59,6 @@ test_iperf3() { pane_or_context_run "${__cctx}" 'rm -f c*.json' - pane_or_context_run_bg "${__sctx}" \ - 'for i in $(seq 0 '${__procs}'); do' \ - ' (iperf3 -s1 -p'${__port}' -i'${__time}') &' \ - ' echo $! > s${i}.pid; ' \ - 'done' \ - - sleep 1 # Wait for server to be ready - # A 1s wait for connection on what's basically a local link # indicates something is pretty wrong __timeout=1000 @@ -55,17 +73,12 @@ test_iperf3() { ' wait' \ ')' - # Kill the server, just in case -1 didn't work right - pane_or_context_run "${__sctx}" 'kill -INT $(cat s*.pid); rm s*.pid' - __jval=".end.sum_received.bits_per_second" __bw=$(pane_or_context_output "${__cctx}" \ 'cat c*.json | jq -rMs "map('${__jval}') | add"') TEST_ONE_subs="$(list_add_pair "${TEST_ONE_subs}" "__${__var}__" "${__bw}" )" - - sleep 3 # Wait for kernel to free up ports } test_one_line() { @@ -283,6 +296,12 @@ test_one_line() { "lat") table_value_latency ${__arg} || TEST_ONE_perf_nok=1 ;; + "iperf3s") + test_iperf3s ${__arg} + ;; + "iperf3k") + test_iperf3k ${__arg} + ;; "iperf3") test_iperf3 ${__arg} ;; diff --git a/test/perf/passt_tcp b/test/perf/passt_tcp index 7046f3c..9363922 100644 --- a/test/perf/passt_tcp +++ b/test/perf/passt_tcp @@ -50,22 +50,25 @@ th MTU 256B 576B 1280B 1500B 9000B 65520B tr TCP throughput over IPv6: guest to host +iperf3s ns 100${i}2 __THREADS__ + bw - bw - - guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M bw __BW__ 1.2 1.5 guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M bw __BW__ 1.6 1.8 guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 4.0 5.0 guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 16M +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 16M bw __BW__ 7.0 8.0 +iperf3k ns + tl TCP RR latency over IPv6: guest to host lat - lat - @@ -86,27 +89,30 @@ nsb tcp_crr --nolog -6 gout LAT tcp_crr --nolog -6 -c -H __GW6__%__IFNAME__ | sed -n 's/^throughput=\(.*\)/\1/p' lat __LAT__ 500 400 - tr TCP throughput over IPv4: guest to host +iperf3s ns 100${i}2 __THREADS__ + guest ip link set dev __IFNAME__ mtu 256 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 1M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 1M bw __BW__ 0.2 0.3 guest ip link set dev __IFNAME__ mtu 576 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 1M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 1M bw __BW__ 0.5 0.8 guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M bw __BW__ 1.2 1.5 guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 4M bw __BW__ 1.6 1.8 guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 4.0 5.0 guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 16M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -w 16M bw __BW__ 7.0 8.0 +iperf3k ns + tl TCP RR latency over IPv4: guest to host lat - lat - @@ -127,24 +133,27 @@ nsb tcp_crr --nolog -4 gout LAT tcp_crr --nolog -4 -c -H __GW__ | sed -n 's/^throughput=\(.*\)/\1/p' lat __LAT__ 500 400 - tr TCP throughput over IPv6: host to guest +iperf3s guest 100${i}1 __THREADS__ + bw - bw - ns ip link set dev lo mtu 1280 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 1.0 1.2 ns ip link set dev lo mtu 1500 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 2.0 3.0 ns ip link set dev lo mtu 9000 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 5.0 6.0 ns ip link set dev lo mtu 65520 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 6.0 6.8 ns ip link set dev lo mtu 65535 +iperf3k guest + tl TCP RR latency over IPv6: host to guest lat - lat - @@ -169,27 +178,31 @@ lat __LAT__ 500 350 tr TCP throughput over IPv4: host to guest +iperf3s guest 100${i}1 __THREADS__ + ns ip link set dev lo mtu 256 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 0.3 0.5 ns ip link set dev lo mtu 576 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 0.5 1.0 ns ip link set dev lo mtu 1280 ns ip addr add ::1 dev lo -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 2.0 3.0 ns ip link set dev lo mtu 1500 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 2.0 3.0 ns ip link set dev lo mtu 9000 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 5.0 6.0 ns ip link set dev lo mtu 65520 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 6.0 6.8 ns ip link set dev lo mtu 65535 +iperf3k guest + tl TCP RR latency over IPv4: host to guest lat - lat - diff --git a/test/perf/passt_udp b/test/perf/passt_udp index a117b6a..12d8fbb 100644 --- a/test/perf/passt_udp +++ b/test/perf/passt_udp @@ -41,23 +41,26 @@ report passt udp __THREADS__ __FREQ__ th MTU 256B 576B 1280B 1500B 9000B 65520B - tr UDP throughput over IPv6: guest to host +iperf3s ns 100${i}2 __THREADS__ + bw - bw - guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 0.8 1.2 guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.0 1.5 guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 5G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 5G bw __BW__ 4.0 5.0 guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest ns __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G bw __BW__ 4.0 5.0 +iperf3k ns + tl UDP RR latency over IPv6: guest to host lat - lat - @@ -70,25 +73,29 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: guest to host +iperf3s ns 100${i}2 __THREADS__ + guest ip link set dev __IFNAME__ mtu 256 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 500M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 500M bw __BW__ 0.0 0.0 guest ip link set dev __IFNAME__ mtu 576 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 1G bw __BW__ 0.4 0.6 guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 0.8 1.2 guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.0 1.5 guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 6G bw __BW__ 4.0 5.0 guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest ns __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G bw __BW__ 4.0 5.0 +iperf3k ns + tl UDP RR latency over IPv4: guest to host lat - lat - @@ -101,21 +108,25 @@ lat __LAT__ 200 150 tr UDP throughput over IPv6: host to guest +iperf3s guest 100${i}1 __THREADS__ + bw - bw - ns ip link set dev lo mtu 1280 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 0.8 1.2 ns ip link set dev lo mtu 1500 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 1.0 1.5 ns ip link set dev lo mtu 9000 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 3.0 4.0 ns ip link set dev lo mtu 65520 -iperf3 BW ns guest ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 3.0 4.0 +iperf3k guest + tl UDP RR latency over IPv6: host to guest lat - lat - @@ -130,26 +141,30 @@ ns ip link set dev lo mtu 65535 tr UDP throughput over IPv4: host to guest +iperf3s guest 100${i}1 __THREADS__ + ns ip link set dev lo mtu 256 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G bw __BW__ 0.0 0.0 ns ip link set dev lo mtu 576 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G bw __BW__ 0.4 0.6 ns ip link set dev lo mtu 1280 ns ip addr add ::1 dev lo -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 0.8 1.2 ns ip link set dev lo mtu 1500 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.0 1.5 ns ip link set dev lo mtu 9000 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 3.0 4.0 ns ip link set dev lo mtu 65520 -iperf3 BW ns guest 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 3.0 4.0 +iperf3k guest + tl UDP RR latency over IPv4: host to guest lat - lat - diff --git a/test/perf/pasta_tcp b/test/perf/pasta_tcp index 9e9dc37..a8938c3 100644 --- a/test/perf/pasta_tcp +++ b/test/perf/pasta_tcp @@ -37,21 +37,24 @@ report pasta lo_tcp __THREADS__ __FREQ__ th MTU 1500B 4000B 16384B 65535B - tr TCP throughput over IPv6: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev lo mtu 1500 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 4000 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 16384 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 65535 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 +iperf3k host + tl TCP RR latency over IPv6: ns to host lat - lat - @@ -72,19 +75,23 @@ lat __LAT__ 500 350 tr TCP throughput over IPv4: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev lo mtu 1500 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 4000 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 16384 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 ns ip link set dev lo mtu 65535 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 +iperf3k host + tl TCP RR latency over IPv4: ns to host lat - lat - @@ -103,14 +110,17 @@ nsout LAT tcp_crr --nolog -P 10003 -C 10013 -4 -c -H 127.0.0.1 | sed -n 's/^thro hostw lat __LAT__ 500 350 - tr TCP throughput over IPv6: host to ns +iperf3s ns 100${i}2 __THREADS__ + bw - bw - bw - -iperf3 BW host ns ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 +iperf3k ns + tl TCP RR latency over IPv6: host to ns lat - lat - @@ -131,12 +141,16 @@ lat __LAT__ 1000 700 tr TCP throughput over IPv4: host to ns +iperf3s ns 100${i}2 __THREADS__ + bw - bw - bw - -iperf3 BW host ns 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 +iperf3k ns + tl TCP RR latency over IPv4: host to ns lat - lat - @@ -158,7 +172,6 @@ lat __LAT__ 1000 700 te - test pasta: throughput and latency (connections via tap) nsout GW ip -j -4 route show|jq -rM '.[] | select(.dst == "default").gateway' @@ -173,21 +186,24 @@ report pasta tap_tcp __THREADS__ __FREQ__ th MTU 1500B 4000B 16384B 65520B - tr TCP throughput over IPv6: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 512k +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 512k bw __BW__ 0.2 0.4 ns ip link set dev __IFNAME__ mtu 4000 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 1M +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 1M bw __BW__ 0.3 0.5 ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 1.5 2.0 ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 2.0 2.5 +iperf3k host + tl TCP RR latency over IPv6: ns to host lat - lat - @@ -208,19 +224,23 @@ lat __LAT__ 1500 500 tr TCP throughput over IPv4: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 512k +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 512k bw __BW__ 0.2 0.4 ns ip link set dev __IFNAME__ mtu 4000 -iperf3s BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 1M +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 1M bw __BW__ 0.3 0.5 ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 1.5 2.0 ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -w 8M bw __BW__ 2.0 2.5 +iperf3k host + tl TCP RR latency over IPv4: ns to host lat - lat - @@ -239,16 +259,19 @@ nsout LAT tcp_crr --nolog -P 10003 -C 10013 -4 -c -H __GW__ | sed -n 's/^through hostw lat __LAT__ 1500 500 - tr TCP throughput over IPv6: host to ns +iperf3s ns 100${i}2 __THREADS__ + nsout IFNAME ip -j link show | jq -rM '.[] | select(.link_type == "ether").ifname' nsout ADDR6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[] | select(.scope == "global" and .prefixlen == 64).local' bw - bw - bw - -iperf3 BW host ns __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 8.0 10.0 +iperf3k ns + tl TCP RR latency over IPv6: host to ns lat - lat - @@ -270,13 +293,17 @@ lat __LAT__ 5000 10000 tr TCP throughput over IPv4: host to ns +iperf3s ns 100${i}2 __THREADS__ + nsout ADDR ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[0].local' bw - bw - bw - -iperf3 BW host ns __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 8.0 10.0 +iperf3k ns + tl TCP RR latency over IPv4: host to ns lat - lat - diff --git a/test/perf/pasta_udp b/test/perf/pasta_udp index 3de73a0..0628bd9 100644 --- a/test/perf/pasta_udp +++ b/test/perf/pasta_udp @@ -33,19 +33,23 @@ th MTU 1500B 4000B 16384B 65535B tr UDP throughput over IPv6: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev lo mtu 1500 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.0 1.5 ns ip link set dev lo mtu 4000 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.2 1.8 ns ip link set dev lo mtu 16384 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G bw __BW__ 5.0 6.0 ns ip link set dev lo mtu 65535 -iperf3 BW ns host ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k host + tl UDP RR latency over IPv6: ns to host lat - lat - @@ -57,19 +61,23 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev lo mtu 1500 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.0 1.5 ns ip link set dev lo mtu 4000 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 1.2 1.8 ns ip link set dev lo mtu 16384 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G bw __BW__ 5.0 6.0 ns ip link set dev lo mtu 65535 -iperf3 BW ns host 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k host + tl UDP RR latency over IPv4: ns to host lat - lat - @@ -81,12 +89,16 @@ lat __LAT__ 200 150 tr UDP throughput over IPv6: host to ns +iperf3s ns 100${i}2 __THREADS__ + bw - bw - bw - -iperf3 BW host ns ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k ns + tl UDP RR latency over IPv6: host to ns lat - lat - @@ -98,12 +110,15 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: host to ns +iperf3s ns 100${i}2 __THREADS__ bw - bw - bw - -iperf3 BW host ns 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k ns + tl UDP RR latency over IPv4: host to ns lat - lat - @@ -129,19 +144,23 @@ report pasta tap_udp 1 __FREQ__ th MTU 1500B 4000B 16384B 65520B tr UDP throughput over IPv6: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 0.3 0.5 ns ip link set dev __IFNAME__ mtu 4000 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 0.5 0.8 ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G bw __BW__ 3.0 4.0 ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns host __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G bw __BW__ 6.0 7.0 +iperf3k host + tl UDP RR latency over IPv6: ns to host lat - lat - @@ -153,19 +172,23 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: ns to host +iperf3s host 100${i}3 __THREADS__ + ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G bw __BW__ 0.3 0.5 ns ip link set dev __IFNAME__ mtu 4000 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G bw __BW__ 0.5 0.8 ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G bw __BW__ 3.0 4.0 ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns host __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G bw __BW__ 6.0 7.0 +iperf3k host + tl UDP RR latency over IPv4: ns to host lat - lat - @@ -175,16 +198,19 @@ nsout LAT udp_rr --nolog -P 10003 -C 10013 -4 -c -H __GW__ | sed -n 's/^throughp hostw lat __LAT__ 200 150 - tr UDP throughput over IPv6: host to ns +iperf3s ns 100${i}2 __THREADS__ + nsout IFNAME ip -j link show | jq -rM '.[] | select(.link_type == "ether").ifname' nsout ADDR6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[] | select(.scope == "global" and .prefixlen == 64).local' bw - bw - bw - -iperf3 BW host ns __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k ns + tl UDP RR latency over IPv6: host to ns lat - lat - @@ -196,13 +222,17 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: host to ns +iperf3s ns 100${i}2 __THREADS__ + nsout ADDR ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[0].local' bw - bw - bw - -iperf3 BW host ns __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G bw __BW__ 7.0 9.0 +iperf3k ns + tl UDP RR latency over IPv4: host to ns lat - lat - -- 2.41.0
Currently we make TCP throughput measurements for spliced connections with a number of different MTU values. However, the results from this aren't really interesting. Unlike with tap connections, spliced connections only involve the loopback interface on host and container, not a "real" external interface. lo typically has an MTU of 65535 and there is very little reason to ever change that. So, the measurements for smaller MTUs are rarely going to be relevant. In addition, the fact that we can offload all the {de,}packetization to the kernel with splice(2) means that the throughput difference between these MTUs isn't very great anyway. Remove the short MTUs and only show spliced throughput for the normal 65535 byte loopback MTU. This reduces runtime of the performance tests on my laptop by about 1 minute (out of ~24 minutes). Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/pasta_tcp | 53 +-------------------------------------------- 1 file changed, 1 insertion(+), 52 deletions(-) diff --git a/test/perf/pasta_tcp b/test/perf/pasta_tcp index a8938c3..3a8ad40 100644 --- a/test/perf/pasta_tcp +++ b/test/perf/pasta_tcp @@ -35,39 +35,23 @@ hout FREQ [ -n "__FREQ_CPUFREQ__" ] && echo __FREQ_CPUFREQ__ || echo __FREQ_PROC info Throughput in Gbps, latency in µs, __THREADS__ threads at __FREQ__ GHz, __STREAMS__ streams each report pasta lo_tcp __THREADS__ __FREQ__ -th MTU 1500B 4000B 16384B 65535B +th MTU 65535B tr TCP throughput over IPv6: ns to host iperf3s host 100${i}3 __THREADS__ -ns ip link set dev lo mtu 1500 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 4000 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 16384 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 65535 iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 iperf3k host tl TCP RR latency over IPv6: ns to host -lat - -lat - -lat - hostb tcp_rr --nolog -P 10003 -C 10013 -6 nsout LAT tcp_rr --nolog -P 10003 -C 10013 -6 -c -H ::1 | sed -n 's/^throughput=\(.*\)/\1/p' hostw lat __LAT__ 150 100 tl TCP CRR latency over IPv6: ns to host -lat - -lat - -lat - hostb tcp_crr --nolog -P 10003 -C 10013 -6 nsout LAT tcp_crr --nolog -P 10003 -C 10013 -6 -c -H ::1 | sed -n 's/^throughput=\(.*\)/\1/p' hostw @@ -77,34 +61,18 @@ lat __LAT__ 500 350 tr TCP throughput over IPv4: ns to host iperf3s host 100${i}3 __THREADS__ -ns ip link set dev lo mtu 1500 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 4000 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 16384 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 15.0 20.0 -ns ip link set dev lo mtu 65535 iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 iperf3k host tl TCP RR latency over IPv4: ns to host -lat - -lat - -lat - hostb tcp_rr --nolog -P 10003 -C 10013 -4 nsout LAT tcp_rr --nolog -P 10003 -C 10013 -4 -c -H 127.0.0.1 | sed -n 's/^throughput=\(.*\)/\1/p' hostw lat __LAT__ 150 100 tl TCP CRR latency over IPv4: ns to host -lat - -lat - -lat - hostb tcp_crr --nolog -P 10003 -C 10013 -4 nsout LAT tcp_crr --nolog -P 10003 -C 10013 -4 -c -H 127.0.0.1 | sed -n 's/^throughput=\(.*\)/\1/p' hostw @@ -113,27 +81,18 @@ lat __LAT__ 500 350 tr TCP throughput over IPv6: host to ns iperf3s ns 100${i}2 __THREADS__ -bw - -bw - -bw - iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 iperf3k ns tl TCP RR latency over IPv6: host to ns -lat - -lat - -lat - nsb tcp_rr --nolog -P 10002 -C 10012 -6 hout LAT tcp_rr --nolog -P 10002 -C 10012 -6 -c -H ::1 | sed -n 's/^throughput=\(.*\)/\1/p' nsw lat __LAT__ 150 100 tl TCP CRR latency over IPv6: host to ns -lat - -lat - -lat - nsb tcp_crr --nolog -P 10002 -C 10012 -6 hout LAT tcp_crr --nolog -P 10002 -C 10012 -6 -c -H ::1 | sed -n 's/^throughput=\(.*\)/\1/p' nsw @@ -143,28 +102,18 @@ lat __LAT__ 1000 700 tr TCP throughput over IPv4: host to ns iperf3s ns 100${i}2 __THREADS__ -bw - -bw - -bw - iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ bw __BW__ 15.0 20.0 iperf3k ns tl TCP RR latency over IPv4: host to ns -lat - -lat - -lat - nsb tcp_rr --nolog -P 10002 -C 10012 -4 hout LAT tcp_rr --nolog -P 10002 -C 10012 -4 -c -H 127.0.0.1 | sed -n 's/^throughput=\(.*\)/\1/p' nsw lat __LAT__ 150 100 tl TCP CRR latency over IPv4: host to ns -lat - -lat - -lat - -sleep 1 nsb tcp_crr --nolog -P 10002 -C 10012 -4 hout LAT tcp_crr --nolog -P 10002 -C 10012 -4 -c -H 127.0.0.1 | sed -n 's/^throughput=\(.*\)/\1/p' nsw -- 2.41.0
Packet size can make a big difference to UDP throughput, so it makes sense to measure it for a variety of different sizes. Currently we do this by adjusting the MTU on the relevant interface before running iperf3. However, the UDP packet size has no inherent connection to the MTU - it's controlled by the sender, and the MTU just affects whether the packet will make it through or be fragmented. The only reason adjusting the MTU works is because iperf3 bases its default packet size on the (path) MTU. We can test this more simply by using the -l option to the iperf3 client to directly control the packet size, instead of adjusting the MTU. As well as simplifying this lets us test different packet sizes for host to ns traffic. We couldn't do that previously because we don't have permission to change the MTU on the host. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/passt_udp | 69 +++++++++++------------------- test/perf/pasta_udp | 100 ++++++++++++++++++++++---------------------- 2 files changed, 75 insertions(+), 94 deletions(-) diff --git a/test/perf/passt_udp b/test/perf/passt_udp index 12d8fbb..10f638f 100644 --- a/test/perf/passt_udp +++ b/test/perf/passt_udp @@ -39,24 +39,21 @@ info Throughput in Gbps, latency in µs, __THREADS__ threads at __FREQ__ GHz, on report passt udp __THREADS__ __FREQ__ -th MTU 256B 576B 1280B 1500B 9000B 65520B +th pktlen 256B 576B 1280B 1500B 9000B 65520B tr UDP throughput over IPv6: guest to host iperf3s ns 100${i}2 __THREADS__ +# (datagram size) = (packet size) - 48: 40 bytes of IPv6 header, 8 of UDP header bw - bw - -guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1232 bw __BW__ 0.8 1.2 -guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1452 bw __BW__ 1.0 1.5 -guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 5G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 5G -l 8952 bw __BW__ 4.0 5.0 -guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G +iperf3 BW guest __GW6__%__IFNAME__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G -l 64372 bw __BW__ 4.0 5.0 iperf3k ns @@ -74,24 +71,19 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: guest to host iperf3s ns 100${i}2 __THREADS__ +# (datagram size) = (packet size) - 28: 20 bytes of IPv4 header, 8 of UDP header -guest ip link set dev __IFNAME__ mtu 256 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 500M +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 500M -l 228 bw __BW__ 0.0 0.0 -guest ip link set dev __IFNAME__ mtu 576 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 1G -l 548 bw __BW__ 0.4 0.6 -guest ip link set dev __IFNAME__ mtu 1280 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1252 bw __BW__ 0.8 1.2 -guest ip link set dev __IFNAME__ mtu 1500 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1472 bw __BW__ 1.0 1.5 -guest ip link set dev __IFNAME__ mtu 9000 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 6G -l 8972 bw __BW__ 4.0 5.0 -guest ip link set dev __IFNAME__ mtu 65520 -iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G +iperf3 BW guest __GW__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 7G -l 65492 bw __BW__ 4.0 5.0 iperf3k ns @@ -109,20 +101,17 @@ lat __LAT__ 200 150 tr UDP throughput over IPv6: host to guest iperf3s guest 100${i}1 __THREADS__ +# (datagram size) = (packet size) - 48: 40 bytes of IPv6 header, 8 of UDP header bw - bw - -ns ip link set dev lo mtu 1280 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1232 bw __BW__ 0.8 1.2 -ns ip link set dev lo mtu 1500 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1452 bw __BW__ 1.0 1.5 -ns ip link set dev lo mtu 9000 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 8952 bw __BW__ 3.0 4.0 -ns ip link set dev lo mtu 65520 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 64372 bw __BW__ 3.0 4.0 iperf3k guest @@ -137,30 +126,23 @@ guestb udp_rr --nolog -P 10001 -C 10011 -6 sleep 1 nsout LAT udp_rr --nolog -P 10001 -C 10011 -6 -c -H ::1 | sed -n 's/^throughput=\(.*\)/\1/p' lat __LAT__ 200 150 -ns ip link set dev lo mtu 65535 tr UDP throughput over IPv4: host to guest iperf3s guest 100${i}1 __THREADS__ +# (datagram size) = (packet size) - 28: 20 bytes of IPv4 header, 8 of UDP header -ns ip link set dev lo mtu 256 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G -l 228 bw __BW__ 0.0 0.0 -ns ip link set dev lo mtu 576 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 1G -l 548 bw __BW__ 0.4 0.6 -ns ip link set dev lo mtu 1280 -ns ip addr add ::1 dev lo -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1252 bw __BW__ 0.8 1.2 -ns ip link set dev lo mtu 1500 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1472 bw __BW__ 1.0 1.5 -ns ip link set dev lo mtu 9000 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 8972 bw __BW__ 3.0 4.0 -ns ip link set dev lo mtu 65520 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -b 3G -l 65492 bw __BW__ 3.0 4.0 iperf3k guest @@ -175,6 +157,5 @@ guestb udp_rr --nolog -P 10001 -C 10011 -4 sleep 1 nsout LAT udp_rr --nolog -P 10001 -C 10011 -4 -c -H 127.0.0.1 | sed -n 's/^throughput=\(.*\)/\1/p' lat __LAT__ 200 150 -ns ip link set dev lo mtu 65535 te diff --git a/test/perf/pasta_udp b/test/perf/pasta_udp index 0628bd9..5e3db1e 100644 --- a/test/perf/pasta_udp +++ b/test/perf/pasta_udp @@ -29,23 +29,20 @@ info Throughput in Gbps, latency in µs, one thread at __FREQ__ GHz, __STREAMS__ report pasta lo_udp 1 __FREQ__ -th MTU 1500B 4000B 16384B 65535B +th pktlen 1500B 4000B 16384B 65535B tr UDP throughput over IPv6: ns to host iperf3s host 100${i}3 __THREADS__ +# (datagram size) = (packet size) - 48: 40 bytes of IPv6 header, 8 of UDP header -ns ip link set dev lo mtu 1500 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1452 bw __BW__ 1.0 1.5 -ns ip link set dev lo mtu 4000 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 bw __BW__ 1.2 1.8 -ns ip link set dev lo mtu 16384 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G -l 16336 bw __BW__ 5.0 6.0 -ns ip link set dev lo mtu 65535 -iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW ns ::1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G -l 65487 bw __BW__ 7.0 9.0 iperf3k host @@ -62,18 +59,15 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: ns to host iperf3s host 100${i}3 __THREADS__ +# (datagram size) = (packet size) - 28: 20 bytes of IPv4 header, 8 of UDP header -ns ip link set dev lo mtu 1500 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1372 bw __BW__ 1.0 1.5 -ns ip link set dev lo mtu 4000 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 bw __BW__ 1.2 1.8 -ns ip link set dev lo mtu 16384 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 10G -l 16356 bw __BW__ 5.0 6.0 -ns ip link set dev lo mtu 65535 -iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW ns 127.0.0.1 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 15G -l 65507 bw __BW__ 7.0 9.0 iperf3k host @@ -91,10 +85,13 @@ lat __LAT__ 200 150 tr UDP throughput over IPv6: host to ns iperf3s ns 100${i}2 __THREADS__ -bw - -bw - -bw - -iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1452 +bw __BW__ 1.0 1.5 +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 +bw __BW__ 1.2 1.8 +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 10G -l 16336 +bw __BW__ 5.0 6.0 +iperf3 BW host ::1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -l 16336 bw __BW__ 7.0 9.0 iperf3k ns @@ -111,10 +108,13 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: host to ns iperf3s ns 100${i}2 __THREADS__ -bw - -bw - -bw - -iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 1372 +bw __BW__ 1.0 1.5 +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 +bw __BW__ 1.2 1.8 +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 10G -l 16356 +bw __BW__ 5.0 6.0 +iperf3 BW host 127.0.0.1 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -l 65507 bw __BW__ 7.0 9.0 iperf3k ns @@ -141,22 +141,19 @@ nsout IFNAME ip -j link show | jq -rM '.[] | select(.link_type == "ether").ifnam info Throughput in Gbps, latency in µs, one thread at __FREQ__ GHz, __STREAMS__ streams report pasta tap_udp 1 __FREQ__ -th MTU 1500B 4000B 16384B 65520B +th pktlen 1500B 4000B 16384B 65520B tr UDP throughput over IPv6: ns to host iperf3s host 100${i}3 __THREADS__ +# (datagram size) = (packet size) - 48: 40 bytes of IPv6 header, 8 of UDP header -ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1472 bw __BW__ 0.3 0.5 -ns ip link set dev __IFNAME__ mtu 4000 -iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 bw __BW__ 0.5 0.8 -ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G -l 16356 bw __BW__ 3.0 4.0 -ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW ns __GW6__%__IFNAME__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G -l 65472 bw __BW__ 6.0 7.0 iperf3k host @@ -173,18 +170,15 @@ lat __LAT__ 200 150 tr UDP throughput over IPv4: ns to host iperf3s host 100${i}3 __THREADS__ +# (datagram size) = (packet size) - 28: 20 bytes of IPv4 header, 8 of UDP header -ns ip link set dev __IFNAME__ mtu 1500 -iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1472 bw __BW__ 0.3 0.5 -ns ip link set dev __IFNAME__ mtu 4000 -iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 bw __BW__ 0.5 0.8 -ns ip link set dev __IFNAME__ mtu 16384 -iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 4G -l 16356 bw __BW__ 3.0 4.0 -ns ip link set dev __IFNAME__ mtu 65520 -iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G +iperf3 BW ns __GW__ 100${i}3 __THREADS__ __TIME__ __OPTS__ -b 6G -l 65492 bw __BW__ 6.0 7.0 iperf3k host @@ -203,10 +197,13 @@ iperf3s ns 100${i}2 __THREADS__ nsout IFNAME ip -j link show | jq -rM '.[] | select(.link_type == "ether").ifname' nsout ADDR6 ip -j -6 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[] | select(.scope == "global" and .prefixlen == 64).local' -bw - -bw - -bw - -iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1472 +bw __BW__ 0.3 0.5 +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 +bw __BW__ 0.5 0.8 +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 4G -l 16356 +bw __BW__ 3.0 4.0 +iperf3 BW host __ADDR6__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -l 65472 bw __BW__ 7.0 9.0 iperf3k ns @@ -225,10 +222,13 @@ tr UDP throughput over IPv4: host to ns iperf3s ns 100${i}2 __THREADS__ nsout ADDR ip -j -4 addr show|jq -rM '.[] | select(.ifname == "__IFNAME__").addr_info[0].local' -bw - -bw - -bw - -iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 2G -l 1472 +bw __BW__ 0.3 0.5 +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 3G -l 3972 +bw __BW__ 0.5 0.8 +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 4G -l 16356 +bw __BW__ 3.0 4.0 +iperf3 BW host __ADDR__ 100${i}2 __THREADS__ __TIME__ __OPTS__ -b 15G -l 65492 bw __BW__ 7.0 9.0 iperf3k ns -- 2.41.0
The TCP packet size used on the passt L2 link (qemu socket) makes a huge difference to passt/pasta throughput; many of passt's overheads (chiefly syscalls) are per-packet. That packet size is largely determined by the MTU on the L2 link, so we benchmark for a number of different MTUs. That works well for the guest to host transfers. For the host to guest transfers, we purport to test for different MTUs, but we're not actually adjusting anything interesting. The host to guest transfers adjust the MTU on the "host's" (actually ns) loopback interface. However, that only affects the packet size for the socket going to passt, not the packet size for the L2 link that passt manages - passt can and will repack the stream into packets of its own size. Since the depacketization on that socket is handled by the kernel it doesn't have a lot of bearing on passt's performance. We can't fix this by changing the L2 link MTU from the guest side (as we do for guest to host), because that would only change the guest's view of the MTU, passt would still think it has the large MTU. We could test this by using the --mtu option to passt, but that would require restarting passt for each run, which is awkward in the current setup. So, for now, drop all the "small MTU" tests for host to guest. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/passt_tcp | 37 ++++++++----------------------------- 1 file changed, 8 insertions(+), 29 deletions(-) diff --git a/test/perf/passt_tcp b/test/perf/passt_tcp index 9363922..205b9af 100644 --- a/test/perf/passt_tcp +++ b/test/perf/passt_tcp @@ -138,19 +138,11 @@ iperf3s guest 100${i}1 __THREADS__ bw - bw - -ns ip link set dev lo mtu 1280 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 1.0 1.2 -ns ip link set dev lo mtu 1500 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 2.0 3.0 -ns ip link set dev lo mtu 9000 -iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 5.0 6.0 -ns ip link set dev lo mtu 65520 +bw - +bw - +bw - iperf3 BW ns ::1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 6.0 6.8 -ns ip link set dev lo mtu 65535 iperf3k guest @@ -180,26 +172,13 @@ lat __LAT__ 500 350 tr TCP throughput over IPv4: host to guest iperf3s guest 100${i}1 __THREADS__ -ns ip link set dev lo mtu 256 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 0.3 0.5 -ns ip link set dev lo mtu 576 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 0.5 1.0 -ns ip link set dev lo mtu 1280 -ns ip addr add ::1 dev lo -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 2.0 3.0 -ns ip link set dev lo mtu 1500 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 2.0 3.0 -ns ip link set dev lo mtu 9000 -iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ -bw __BW__ 5.0 6.0 -ns ip link set dev lo mtu 65520 +bw - +bw - +bw - +bw - +bw - iperf3 BW ns 127.0.0.1 100${i}1 __THREADS__ __TIME__ __OPTS__ bw __BW__ 6.0 6.8 -ns ip link set dev lo mtu 65535 iperf3k guest -- 2.41.0
We always set --pacing-timer when invoking iperf3. However, the iperf3 man page implies this is only relevant for the -b option. We only use the -b option for the UDP tests, not TCP, so remove --pacing-timer from the TCP cases. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/passt_tcp | 2 +- test/perf/pasta_tcp | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/test/perf/passt_tcp b/test/perf/passt_tcp index 205b9af..da4e369 100644 --- a/test/perf/passt_tcp +++ b/test/perf/passt_tcp @@ -41,7 +41,7 @@ set THREADS 1 set STREAMS 8 set TIME 10 hout OMIT echo __TIME__ / 6 | bc -l -set OPTS -Z -P __STREAMS__ -l 1M -O__OMIT__ --pacing-timer 1000000 +set OPTS -Z -P __STREAMS__ -l 1M -O__OMIT__ info Throughput in Gbps, latency in µs, one thread at __FREQ__ GHz, __STREAMS__ streams report passt tcp __THREADS__ __FREQ__ diff --git a/test/perf/pasta_tcp b/test/perf/pasta_tcp index 3a8ad40..11c73f8 100644 --- a/test/perf/pasta_tcp +++ b/test/perf/pasta_tcp @@ -25,7 +25,7 @@ set THREADS 2 set STREAMS 2 set TIME 10 hout OMIT echo __TIME__ / 6 | bc -l -set OPTS -Z -w 4M -l 1M -P __STREAMS__ -O__OMIT__ --pacing-timer 10000 +set OPTS -Z -w 4M -l 1M -P __STREAMS__ -O__OMIT__ hout FREQ_PROCFS (echo "scale=1"; sed -n 's/cpu MHz.*: \([0-9]*\)\..*$/(\1+10^2\/2)\/10^3/p' /proc/cpuinfo) | bc -l | head -n1 hout FREQ_CPUFREQ (echo "scale=1"; printf '( %i + 10^5 / 2 ) / 10^6\n' $(cat /sys/devices/system/cpu/cpu0/cpufreq/scaling_max_freq) ) | bc -l @@ -128,7 +128,7 @@ nsout GW6 ip -j -6 route show|jq -rM '.[] | select(.dst == "default").gateway' nsout IFNAME ip -j link show | jq -rM '.[] | select(.link_type == "ether").ifname' set THREADS 1 set STREAMS 2 -set OPTS -Z -P __STREAMS__ -i1 -O__OMIT__ --pacing-timer 100000 +set OPTS -Z -P __STREAMS__ -i1 -O__OMIT__ info Throughput in Gbps, latency in µs, one thread at __FREQ__ GHz, __STREAMS__ streams report pasta tap_tcp __THREADS__ __FREQ__ -- 2.41.0
For the TCP throughput tests, we use iperf3's -O "omit" option which ignores results for the given time at the beginning of the test. Currently we calculate this as 1/6th of the test measurement time. The purpose of -O, however, is to skip over the TCP slow start period, which in no way depends on the overall length of the test. The slow start time is roughly speaking log_2 ( max_window_size / MSS ) * round_trip_time These factors all vary between tests and machines we're running on, but we can estimate some reasonable bounds for them: * The maximum window size is bounded by the buffer sizes at each end, which shouldn't exceed 16MiB * The mss varies with the MTU we use, but the smallest we use in tests is ~256 bytes * Round trip time will vary with the system, but with these essentially local transfers it will typically be well under 1ms (on my laptop it is closer to 0.03ms) That gives a worst case slow start time of about 16ms. Setting an omit time of 0.1s uniformly is therefore more than enough, and substantially smaller than what we calculate now for the default case (10s / 6 ~= 1.7s). This reduces total time for the standard benchmark run by around 30s. Signed-off-by: David Gibson <david(a)gibson.dropbear.id.au> --- test/perf/passt_tcp | 2 +- test/perf/pasta_tcp | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/test/perf/passt_tcp b/test/perf/passt_tcp index da4e369..631a407 100644 --- a/test/perf/passt_tcp +++ b/test/perf/passt_tcp @@ -40,7 +40,7 @@ hout FREQ [ -n "__FREQ_CPUFREQ__" ] && echo __FREQ_CPUFREQ__ || echo __FREQ_PROC set THREADS 1 set STREAMS 8 set TIME 10 -hout OMIT echo __TIME__ / 6 | bc -l +set OMIT 0.1 set OPTS -Z -P __STREAMS__ -l 1M -O__OMIT__ info Throughput in Gbps, latency in µs, one thread at __FREQ__ GHz, __STREAMS__ streams diff --git a/test/perf/pasta_tcp b/test/perf/pasta_tcp index 11c73f8..7777532 100644 --- a/test/perf/pasta_tcp +++ b/test/perf/pasta_tcp @@ -24,7 +24,7 @@ ns /sbin/sysctl -w net.ipv4.tcp_timestamps=0 set THREADS 2 set STREAMS 2 set TIME 10 -hout OMIT echo __TIME__ / 6 | bc -l +set OMIT 0.1 set OPTS -Z -w 4M -l 1M -P __STREAMS__ -O__OMIT__ hout FREQ_PROCFS (echo "scale=1"; sed -n 's/cpu MHz.*: \([0-9]*\)\..*$/(\1+10^2\/2)\/10^3/p' /proc/cpuinfo) | bc -l | head -n1 -- 2.41.0
On Mon, 6 Nov 2023 18:08:25 +1100 David Gibson <david(a)gibson.dropbear.id.au> wrote:Our standard "make check" includes a number of benchmarks, which take quite a long time to run. This series makes a number of improvements to how we run these, which reduces wasted time and reduces the full run time by some 10-12 minutes. David Gibson (8): test/perf: Remove stale iperf3c/iperf3s directives test/perf: Get iperf3 stats from client side test/perf: Start iperf3 server less often test/perf: Small MTUs for spliced TCP aren't interesting test/perf: Explicitly control UDP packet length, instead of MTU test/perf: "MTU" changes in passt_tcp host to guest aren't useful test/perf: Remove unnecessary --pacing-timer options test/perf: Simplify calculation of "omit" time for TCP throughputApplied. -- Stefano