Skip to content

Commit

Permalink
deploy
Browse files Browse the repository at this point in the history
  • Loading branch information
bmah888 committed Feb 9, 2024
1 parent 97e56ed commit fe3e626
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 11 deletions.
28 changes: 24 additions & 4 deletions _sources/faq.rst.txt
Original file line number Diff line number Diff line change
Expand Up @@ -22,17 +22,37 @@ What is the history of iperf3, and what is the difference between iperf2 and ipe
current development is focused is on using UDP for latency testing, as well
as broad platform support.

As of this writing (2017), both iperf2 and iperf3 are being actively
In 2023, iperf3 was modified and restructured to support
multi-threading, so that it uses one thread per test stream. This
allows it to use multiple CPU cores during tests, which in turn
permit it to keep up with continually increasing network link and
path bandwidths across the backbones of ESnet and other network
providers.

As of this writing (2024), both iperf2 and iperf3 are being actively
(although independently) developed. We recommend being familiar with
both tools, and use whichever tool’s features best match your needs.

A feature comparison of iperf2, iperf3, and nuttcp is available at:
https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/throughput-tool-comparision/

iperf3 parallel stream performance is much less than iperf2. Why?
iperf3 is single threaded, and iperf2 is multi-threaded. We
recommend using iperf2 for parallel streams.
If you want to use multiple iperf3 streams use the method described `here <https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/>`_.
Versions of iperf3 before version 3.16 were all single threaded, and
iperf2 is multi-threaded. This could result in a performance gap
because iperf3 was only able to use one CPU core on a host, which
turned into a bottleneck when trying to do high bitrate tests
(faster than about 25 Gbps).

Beginning with version 3.16, iperf3 is multi-threaded, which allows
it to take advantage of multiple CPU cores during a test (one thread
per stream). iperf3 has been observed to send and receive
approximately 160Gbps on a 200Gbps path in a test involving multiple
TCP flows, with little or no tuning.

Prior to multi-threading support in iperf3, one might need to use
the method described `here
<https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/>`_
to achieve faster speeds.

I’m trying to use iperf3 on Windows, but having trouble. What should I do?
iperf3 is not officially supported on Windows, but iperf2 is. We
Expand Down
2 changes: 1 addition & 1 deletion _sources/invoking.rst.txt
Original file line number Diff line number Diff line change
Expand Up @@ -194,7 +194,7 @@ the executable.
--rcv-timeout #
set idle timeout for receiving data during active tests. The
receiver will halt a test if no data is received from the sender
for this number of ms (default to 12000 ms, or 2 minutes).
for this number of ms (default to 120000 ms, or 2 minutes).
--snd-timeout #
set timeout for unacknowledged TCP data (on both test and con-
Expand Down
24 changes: 20 additions & 4 deletions faq.html
Original file line number Diff line number Diff line change
Expand Up @@ -138,15 +138,31 @@
iperf3. iperf2.0.8, released in 2015, made iperf2 a useful tool. iperf2’s
current development is focused is on using UDP for latency testing, as well
as broad platform support.</p>
<p>As of this writing (2017), both iperf2 and iperf3 are being actively
<p>In 2023, iperf3 was modified and restructured to support
multi-threading, so that it uses one thread per test stream. This
allows it to use multiple CPU cores during tests, which in turn
permit it to keep up with continually increasing network link and
path bandwidths across the backbones of ESnet and other network
providers.</p>
<p>As of this writing (2024), both iperf2 and iperf3 are being actively
(although independently) developed. We recommend being familiar with
both tools, and use whichever tool’s features best match your needs.</p>
<p>A feature comparison of iperf2, iperf3, and nuttcp is available at:
<a class="reference external" href="https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/throughput-tool-comparision/">https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/throughput-tool-comparision/</a></p>
</dd>
<dt>iperf3 parallel stream performance is much less than iperf2. Why?</dt><dd><p>iperf3 is single threaded, and iperf2 is multi-threaded. We
recommend using iperf2 for parallel streams.
If you want to use multiple iperf3 streams use the method described <a class="reference external" href="https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/">here</a>.</p>
<dt>iperf3 parallel stream performance is much less than iperf2. Why?</dt><dd><p>Versions of iperf3 before version 3.16 were all single threaded, and
iperf2 is multi-threaded. This could result in a performance gap
because iperf3 was only able to use one CPU core on a host, which
turned into a bottleneck when trying to do high bitrate tests
(faster than about 25 Gbps).</p>
<p>Beginning with version 3.16, iperf3 is multi-threaded, which allows
it to take advantage of multiple CPU cores during a test (one thread
per stream). iperf3 has been observed to send and receive
approximately 160Gbps on a 200Gbps path in a test involving multiple
TCP flows, with little or no tuning.</p>
<p>Prior to multi-threading support in iperf3, one might need to use
the method described <a class="reference external" href="https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/">here</a>
to achieve faster speeds.</p>
</dd>
<dt>I’m trying to use iperf3 on Windows, but having trouble. What should I do?</dt><dd><p>iperf3 is not officially supported on Windows, but iperf2 is. We
recommend you use iperf2.</p>
Expand Down
2 changes: 1 addition & 1 deletion invoking.html
Original file line number Diff line number Diff line change
Expand Up @@ -318,7 +318,7 @@ <h2>iperf3 Manual Page<a class="headerlink" href="#iperf3-manual-page" title="Li
<span class="o">--</span><span class="n">rcv</span><span class="o">-</span><span class="n">timeout</span> <span class="c1">#</span>
<span class="nb">set</span> <span class="n">idle</span> <span class="n">timeout</span> <span class="k">for</span> <span class="n">receiving</span> <span class="n">data</span> <span class="n">during</span> <span class="n">active</span> <span class="n">tests</span><span class="o">.</span> <span class="n">The</span>
<span class="n">receiver</span> <span class="n">will</span> <span class="n">halt</span> <span class="n">a</span> <span class="n">test</span> <span class="k">if</span> <span class="n">no</span> <span class="n">data</span> <span class="ow">is</span> <span class="n">received</span> <span class="kn">from</span> <span class="nn">the</span> <span class="n">sender</span>
<span class="k">for</span> <span class="n">this</span> <span class="n">number</span> <span class="n">of</span> <span class="n">ms</span> <span class="p">(</span><span class="n">default</span> <span class="n">to</span> <span class="mi">12000</span> <span class="n">ms</span><span class="p">,</span> <span class="ow">or</span> <span class="mi">2</span> <span class="n">minutes</span><span class="p">)</span><span class="o">.</span>
<span class="k">for</span> <span class="n">this</span> <span class="n">number</span> <span class="n">of</span> <span class="n">ms</span> <span class="p">(</span><span class="n">default</span> <span class="n">to</span> <span class="mi">120000</span> <span class="n">ms</span><span class="p">,</span> <span class="ow">or</span> <span class="mi">2</span> <span class="n">minutes</span><span class="p">)</span><span class="o">.</span>

<span class="o">--</span><span class="n">snd</span><span class="o">-</span><span class="n">timeout</span> <span class="c1">#</span>
<span class="nb">set</span> <span class="n">timeout</span> <span class="k">for</span> <span class="n">unacknowledged</span> <span class="n">TCP</span> <span class="n">data</span> <span class="p">(</span><span class="n">on</span> <span class="n">both</span> <span class="n">test</span> <span class="ow">and</span> <span class="n">con</span><span class="o">-</span>
Expand Down
2 changes: 1 addition & 1 deletion searchindex.js

Large diffs are not rendered by default.

0 comments on commit fe3e626

Please sign in to comment.