1
1
iperf3: A TCP, UDP, and SCTP network bandwidth measurement tool (BSD license) https://github.com/esnet/iperf
Перейти к файлу
Bruce A. Mah 787919c4b3
fix: Handle a corner case more gracefully.
If the buffer happens to be holding exactly a sending chunk size,
we no longer arbitrarily quit.

While here, use equivalent, easier-to-read tests in a couple places.

Discussed with @hanvari

Follow-up to #1115.
2021-04-16 14:59:31 -07:00
.github doc: Fix error in domain name for mailing list. 2019-06-28 16:32:13 -07:00
config fix: Make installing of shared libraries work again. (#1014) 2020-06-10 07:34:14 -07:00
contrib Add (extremely) minimal Dockerfile (#824) 2019-10-18 14:14:51 -07:00
docs chore: Copyright date bumps for 2021. 2021-01-15 11:10:06 -08:00
examples enh: Support SO_BINDTODEVICE (#1097) 2020-12-22 15:52:24 -08:00
src fix: Handle a corner case more gracefully. 2021-04-16 14:59:31 -07:00
.gitignore Add recently-created t_auth to .gitignore. 2020-05-28 10:13:48 -07:00
.travis.yml Add Travis CI integration with ESnet's Slack. 2017-09-19 10:43:34 -07:00
aclocal.m4 IP don't fragment support (#1119) 2021-02-16 14:28:54 -08:00
bootstrap.sh Move the automake "foreign" directive from bootstrap.sh to configure.ac (#765) 2018-07-02 10:06:42 -07:00
configure IP don't fragment support (#1119) 2021-02-16 14:28:54 -08:00
configure.ac IP don't fragment support (#1119) 2021-02-16 14:28:54 -08:00
INSTALL Commented 'AX_LIB_SOCKET_NSL' out of configure.ac to fix build problem. 2012-08-20 14:35:58 -07:00
iperf3.spec.in Change applicable http:// URLs to https://. Fix a bad URL in RPM spec. (#759) 2018-06-22 14:09:01 -07:00
LICENSE chore: Copyright date bumps for 2021. 2021-01-15 11:10:06 -08:00
make_release Generate sha256 file automatically so we don't have to copy-and-paste it. 2015-01-09 10:53:03 -08:00
Makefile.am automake / libtool support for programs in the examples/ subdirectory. 2014-03-20 09:52:09 -07:00
Makefile.in enh: Support SO_BINDTODEVICE (#1097) 2020-12-22 15:52:24 -08:00
README.md chore: Copyright date bumps for 2021. 2021-01-15 11:10:06 -08:00
RELNOTES.md chore: releng 3.9 (#1041) 2020-08-14 15:08:27 -07:00
test_commands.sh Issue 982 (#1054) 2020-09-18 10:16:21 -07:00

iperf3: A TCP, UDP, and SCTP network bandwidth measurement tool

Summary

iperf is a tool for active measurements of the maximum achievable bandwidth on IP networks. It supports tuning of various parameters related to timing, protocols, and buffers. For each test it reports the measured throughput / bitrate, loss, and other parameters.

This version, sometimes referred to as iperf3, is a redesign of an original version developed at NLANR/DAST. iperf3 is a new implementation from scratch, with the goal of a smaller, simpler code base, and a library version of the functionality that can be used in other programs. iperf3 also has a number of features found in other tools such as nuttcp and netperf, but were missing from the original iperf. These include, for example, a zero-copy mode and optional JSON output. Note that iperf3 is not backwards compatible with the original iperf.

Primary development for iperf3 takes place on CentOS Linux, FreeBSD, and macOS. At this time, these are the only officially supported platforms, however there have been some reports of success with OpenBSD, NetBSD, Android, Solaris, and other Linux distributions.

iperf3 is principally developed by ESnet / Lawrence Berkeley National Laboratory. It is released under a three-clause BSD license.

For more information see: https://software.es.net/iperf

Source code and issue tracker: https://github.com/esnet/iperf

Obtaining iperf3

Downloads of iperf3 are available at:

https://downloads.es.net/pub/iperf/

To check out the most recent code, clone the git repository at:

https://github.com/esnet/iperf.git

Building iperf3

Prerequisites:

None.

Building

./configure; make; make install

(Note: If configure fails, try running ./bootstrap.sh first)

Invoking iperf3

iperf3 includes a manual page listing all of the command-line options. The manual page is the most up-to-date reference to the various flags and parameters.

For sample command line usage, see:

https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/

Using the default options, iperf is meant to show typical well designed application performance. "Typical well designed application" means avoiding artificial enhancements that work only for testing (such as splice()'ing the data to /dev/null). iperf does also have flags for "extreme best case" optimizations, but they must be explicitly activated.

These flags include:

-Z, --zerocopy            use a 'zero copy' sendfile() method of sending data
-A, --affinity n/n,m      set CPU affinity

Bug Reports

Before submitting a bug report, please make sure you're running the latest version of the code, and confirm that your issue has not already been fixed. Then submit to the iperf3 issue tracker on GitHub:

https://github.com/esnet/iperf/issues

In your issue submission, please indicate the version of iperf3 and what platform you're trying to run on (provide the platform information even if you're not using a supported platform, we might be able to help anyway). Exact command-line arguments will help us recreate your problem. If you're getting error messages, please include them verbatim if possible, but remember to sanitize any sensitive information.

If you have a question about usage or about the code, please do not submit an issue. Please use one of the mailing lists for that.

Relation to iperf 2.x

Note that iperf2 is no longer being developed by its original maintainers. However, beginning in 2014, another developer began fixing bugs and enhancing functionality, and generating releases of iperf2. Both projects (as of late 2017) are currently being developed actively, but independently. The continuing iperf2 development project can be found at https://sourceforge.net/projects/iperf2/.

iperf3 contains a number of options and functions not present in iperf2. In addition, some flags are changed from their iperf2 counterparts:

-C, --linux-congestion    set congestion control algorithm (Linux only)
                          (-Z in iperf2)
--bidir                   bidirectional testing mode
                          (-d in iperf2)

Some iperf2 options are not available in iperf3:

-r, --tradeoff           Do a bidirectional test individually
-T, --ttl                time-to-live, for multicast (default 1)
-x, --reportexclude [CDMSV]   exclude C(connection) D(data) M(multicast) 
                              S(settings) V(server) reports
-y, --reportstyle C      report as a Comma-Separated Values

Also removed is the ability to set the options via environment variables.

Known Issues

A set of known issues is maintained on the iperf3 Web pages:

https://software.es.net/iperf/dev.html#known-issues

This section lists links to user-contributed Web pages regarding iperf3. ESnet and Lawrence Berkeley National Laboratory bear no responsibility for the content of these pages.

iperf, Copyright (c) 2014-2021, The Regents of the University of California, through Lawrence Berkeley National Laboratory (subject to receipt of any required approvals from the U.S. Dept. of Energy). All rights reserved.

If you have questions about your rights to use or distribute this software, please contact Berkeley Lab's Technology Transfer Department at TTD@lbl.gov.

NOTICE. This software is owned by the U.S. Department of Energy. As such, the U.S. Government has been granted for itself and others acting on its behalf a paid-up, nonexclusive, irrevocable, worldwide license in the Software to reproduce, prepare derivative works, and perform publicly and display publicly. Beginning five (5) years after the date permission to assert copyright is obtained from the U.S. Department of Energy, and subject to any subsequent five (5) year renewals, the U.S. Government is granted for itself and others acting on its behalf a paid-up, nonexclusive, irrevocable, worldwide license in the Software to reproduce, prepare derivative works, distribute copies to the public, perform publicly and display publicly, and to permit others to do so.

This code is distributed under a BSD style license, see the LICENSE file for complete information.