Zum Inhalt springen

iperf

Aus Foxwiki
Die 5 zuletzt angesehenen Seiten:  Normen » apache2 » Kategorie:MacOS » Server » iperf

iperf - perform network traffic tests using network sockets. Metrics include throughput and latency or link capacity and re‐ sponsiveness.

Beschreibung

iperf 2 ist ein Testtool, das Netzwerkverkehrsmessungen mithilfe von Netzwerksockets durchführt

  • Zu den unterstützten Leistungsmetriken gehören Durchsatz und Latenz (oder Verbindungskapazität und Reaktionsfähigkeit)
  • Latenzmessungen umfassen sowohl One-Way-Delay (OWD) als auch Round-Trip-Zeiten (RTTs)
  • Iperf kann sowohl TCP- als auch UDP-Sockets (oder -Protokolle) verwenden
  • Es unterstützt unidirektionalen, Vollduplex- Duplex (derselbe Socket) und bidirektionalen Datenverkehr sowie mehrere gleichzeitige Datenverkehrsströme
  • Es unterstützt Multicast-Datenverkehr einschließlich quellenspezifischer Multicast-Verbindungen (SSM)
  • Das Multithreading-Design ermöglicht Spitzenleistungen
  • Die angezeigten Metriken helfen bei der Charakterisierung der Host-zu-Host-Netzwerkleistung
  • Durch die Einstellung der erweiterten Option (-e) werden alle verfügbaren Metriken bereitgestellt
Hinweis

Die Metriken beziehen sich auf Lese- und Schreibvorgänge auf Socket-Ebene

  • Sie enthalten nicht den Overhead, der mit den Header-Protokollebenen

Der Benutzer muss sowohl einen Server (zum Empfangen von Datenverkehr) als auch einen Client (zum Generieren und Senden von Datenverkehr) einrichten, damit ein Test durchgeführt werden kann

  • Client und Server befinden sich in der Regel auf unterschiedlichen Hosts oder Computern, müssen dies aber nicht

Installation

sudo apt install iperf

Aufruf

iperf -s [options]
iperf -c server [options]
iperf -u -s [options]
iperf -u -c server [options]

Optionen

Allgemein

Unix GNU Parameter Beschreibung

-b, --bandwidth set the target bandwidth and optional standard deviation per <mean>,[<stdev>] (See NOTES for suffixes) Setting the target bitrate on the client to 0 will disable bitrate limits (particularly useful for UDP tests). Will limit the read rate on the server.

-e, --enhanced Display enhanced output in reports otherwise use legacy report (ver 2.0.5) formatting (see NOTES)

-f, --format [abkmgBKMG] format to report: adaptive, bits, Bytes, Kbits, Mbits, Gbits, KBytes, MBytes, GBytes (see NOTES for more)

-h, --help print a help synopsis

--hide-ips obscure ip addresses in output (useful when wanting to publish results and not display the full ip addresses. v4 only)

-i, --interval < t | f > sample or display interval reports every t seconds (default) or every frame or burst, i.e. if f is used then the interval will be each frame or burst. The frame interval reporting is experimental. Also suggest a compile with fast-sampling, i.e. ./configure --enable-fastsampling

-l, --len n[kmKM] set read/write buffer size (TCP) or length (UDP) to n (TCP default 128K, UDP default 1470)

--l2checks perform layer 2 length checks on received UDP packets (requires systems that support packet sockets, e.g. Linux)

-m, --print_mss print TCP maximum segment size

--NUM_REPORT_STRUCTS <count> Override the default shared memory size between the traffic thread(s) and reporter thread in order to mitigate mutex lock contentions. The default value of 5000 should be sufficient for 1Gb/s networks. Increase this upon seeing the Warning message of reporter thread too slow. If the Warning message isn't seen, then increasing this won't have any significant effect (other than to use some additional memory.)

-o, --output filename output the report or error message to this specified file

--permit-key [=<value>] Set a key value that must match for the server to accept traffic on a connection. If the option is given without a value on the server a key value will be autogenerated and displayed in its initial settings report. The lifetime of the key is set using --permit-key-timeout and defaults to twenty seconds. The value on clients required the use of '=', e.g. --permit-key=password (even though it's required command line option.) The server will auto-generate a value if '=password' is not given. The value will also be used as part of the transfer id in reports. The option set on the client but not the server will also cause the server to reject the client's traffic. TCP only, no UDP support.

-p, --port m[-n] set client or server port(s) to send or listen on per m (default 5001) w/optional port range per m-n (e.g. -p 6002-6008) (see NOTES)

--sum-dstip sum traffic threads based upon the destination IP address (default is source ip address)

--sum-only set the output to sum reports only. Useful for -P at large values

--tcp-tx-delay n Set TCP_TX_DELAY on the socket. Delay units are milliseconds. Value takes float. See Notes for qdisc requirements.

-t, --time n time in seconds to listen for new traffic connections, receive traffic or send traffic

-u, --udp use UDP rather than TCP

--utc use coordinated universal time (UTC) when outputting time (otherwise use local time)

-w, --window n[kmKM] TCP window size (socket buffer size)

-z, --realtime Request real-time scheduler, if supported.

-B, --bind host[:port][%dev] bind to host, ip address or multicast address, optional port or device (see NOTES)

-C, --compatibility for use with older versions does not sent extra msgs

-M, --mss n set TCP maximum segment size using TCP_MAXSEG

-N, --nodelay set TCP no delay, disabling Nagle's Algorithm

-v, --version print version information and quit

-x, --reportexclude [CDMSV] exclude C(connection) D(data) M(multicast) S(settings) V(server) reports

-y, --reportstyle C|c if set to C or c report results as CSV (comma separated values)

--tcp-cca Set the congestion control algorithm to be used for TCP connections. See SPECIFIC OPTIONS for more

--working-load-cca Set the congestion control algorithm to be used for TCP working loads. See SPECIFIC OPTIONS for more

-Z, --tcp-congestion Set the default congestion control algorithm to be used for new connections. Platforms must support setsockopt's TCP_CONGESTION. (Notes: See sysctl and tcp_allowed_congestion_control for available options. May require root privi‐ leges.)

Server

Unix GNU Parameter Beschreibung

-1, --singleclient set the server to process only one client at a time

-b, --bandwidth n[kmgKMG] set target read rate to n bits/sec. TCP only for the server.

-s, --server run in server mode

--histograms[=binwidth[u],bincount,[lowerci],[upperci]] enable latency histograms for udp packets (-u), for tcp writes (with --trip-times), or for either udp or tcp with --isochronous clients, or for --bounceback. The binning can be modified. Bin widths (default 1 millisecond, append u for microseconds, m for milliseconds) bincount is total bins (default 1000), ci is confidence interval between 0-100% (default lower 5%, upper 95%, 3 stdev 99.7%)

--jitter-histograms[=<binwidth>] enable jitter histograms for udp packets (-u). Optional value is the bin width where units are microseconds and de‐ faults to 100 usecs

--permit-key [=<value>] Set a key value that must match for the server to accept traffic from a client (also set with --permit-key.) The server will auto-generate a globally unique key when the option is given without a value. This value will be dis‐ played in the server's initial settings report. The lifetime of the key is set using --permit-key-timeout and de‐ faults to twenty seconds. TCP only, no UDP support.

--permit-key-timeout <value> Set the lifetime of the permit key in seconds. Defaults to 20 seconds if not set. A value of zero will disable the timer.

--skip-rx-copy Set the server threads to use MSG_TRUNC on recv when possible. This flag causes the received bytes of data to be dis‐ carded and should offload the receiving CPU some.

--tap-dev <dev> Set the receive interface to the TAP device as specified.

--tcp-rx-window-clamp n[kmKM] Set the socket option of TCP_WINDOW_CLAMP, units is bytes.

--test-exchange-timeout <value> Set the maximum wait time for a test exchange in seconds. Defaults to 60 seconds if not set. A value of zero will disable the timeout.

-t, --time n time in seconds to listen for new traffic connections and/or receive traffic (defaults to infinite)

--tos-override <val> set the socket's IP_TOS value for reverse or full duplex traffic. Supported in versions 2.1.5 or greater. Previous versions won't set IP_TOS on reverse traffic. See NOTES for values.

-B, --bind ip | ip%device bind src ip addr and optional src device for receiving

-D, --daemon run the server as a daemon. On Windows this will run the specified command-line under the IPerfService, installing the service if necessary. Note the service is not configured to auto-start or restart - if you need a self-starting service you will need to create an init script or use Windows "sc" commands.

-H, --ssm-host host Set the source host (ip addr) per SSM multicast, i.e. the S of the S,G

-R, --remove remove the IPerfService (Windows only).

-U, --single_udp run in single threaded UDP mode

-V, --ipv6_domain Enable IPv6 reception by setting the domain and socket to AF_INET6 (Can receive on both IPv4 and IPv6)

--tcp-cca Set the congestion control algorithm to be used for TCP connections - will override any client side settings (same as --tcp-congestion)

--working-load Enable support for TCP working loads on UDP traffic streams

--working-load-cca Set the congestion control algorithm to be used for TCP working loads - will override any client side settings

Client

Unix GNU Parameter Beschreibung


-b, --bandwidth n[kmgKMG][,n[kmgKMG]] | n[kmgKMG]pps set target bandwidth to n bits/sec (default 1 Mbit/sec) or n packets per sec. This may be used with TCP or UDP. Op‐ tionally, for variable loads, use format of mean,standard deviation

--bounceback[=n] run a TCP bounceback or rps test with optional number writes in a burst per value of n. The default is ten writes every period and the default period is one second (Note: set size with --bounceback-request). See NOTES on clock un‐ synchronized detections.

--bounceback-hold n request the server to insert a delay of n milliseconds between its read and write (default is no delay)

--bounceback-no-quickack request the server not set the TCP_QUICKACK socket option (disabling TCP ACK delays) during a bounceback test (see NOTES)

--bounceback-period[=n] request the client schedule its send(s) every n seconds (default is one second, use zero value for immediate or con‐ tinuous back to back)

--bounceback-request n set the bounceback request size in units bytes. Default value is 100 bytes.

--bounceback-reply n set the bounceback reply size in units bytes. This supports asymmetric message sizes between the request and the re‐ ply. Default value is zero, which uses the value of --bounceback-request.

--bounceback-txdelay n request the client to delay n seconds between the start of the working load and the bounceback traffic (default is no delay)

--burst-period n Set the burst period in seconds. Defaults to one second. (Note: assumed use case is low duty cycle traffic bursts)

--burst-size n Set the burst size in bytes. Defaults to 1M if no value is given.

-c, --client host | host%device run in client mode, connecting to host where the optional %dev will SO_BINDTODEVICE that output interface (requires root and see NOTES)

--connect-only[=n] only perform a TCP connect (or 3WHS) without any data transfer, useful to measure TCP connect() times. Optional value of n is the total number of connects to do (zero is run forever.) Note that -i will rate limit the connects where -P will create bursts and -t will end the client and hence end its connect attempts.

--connect-retry-time n time value in seconds for application level retries of TCP connect(s). See --connect-retry-timer for the retry time interval. See operating system information for the details of system or kernel TCP connect related settings. This is an application level retry of the connect() call and not the system level connect.

--connect-retry-timer n The minimum time value in seconds to wait before retrying the connect. Note: This a minimum time to wait between re‐ tries and can be longer dependent upon the system connect time taken. See operating system information for the de‐ tails of system or kernel TCP connect related settings.

--dscp set the DSCP field (masking ECN bits) in the TOS byte (used by IP_TOS & setsockopt)

-d, --dualtest Do a bidirectional test simultaneous test using two unidirectional sockets

--fq-rate n[kmgKMG] Set a rate to be used with fair-queuing based socket-level pacing, in bytes or bits per second. Only available on platforms supporting the SO_MAX_PACING_RATE socket option. (Note: Here the suffixes indicate bytes/sec or bits/sec per use of uppercase or lowercase, respectively)

--fq-rate-step n[kmgKMG] Set a step of rate to be used with fair-queuing based socket-level pacing, in bytes or bits per second. Step occurs every fq-rate-step-interval (defaults to one second)

--fq-rate-step-interval n Time in seconds before stepping the fq-rate

--full-duplex run a full duplex test, i.e. traffic in both transmit and receive directions using the same socket

--histograms[=binwidth[u],bincount,[lowerci],[upperci]] enable select()/write() histograms with --tcp-write-times or --bounceback (these options are mutually exclusive.) The binning can be modified. Bin widths (default 100 microseconds, append u for microseconds, m for milliseconds) bin‐ count is total bins (default 10000), ci is confidence interval between 0-100% (default lower 5%, upper 95%, 3 stdev 99.7%)

--ignore-shutdown don't wait on the TCP shutdown or close (fin & finack) rather use the final write as the ending event

--incr-dstip increment the destination ip address when using the parallel (-P) or port range option

--incr-dstport increment the destination port when using the parallel (-P) or port range option

--incr-srcip increment the source ip address when using the parallel (-P) or port range option

--incr-srcport increment the source ip address when using the parallel (-P) or port range option, requires -B to set the src port

--ipg n set the inter-packet gap to n (units of seconds) for packets or within a frame/burst when --isochronous is set

--isochronous[=fps:mean,stdev] send isochronous traffic with frequency frames per second and load defined by mean and standard deviation using a log normal distribution, defaults to 60:20m,0. (Note: Here the suffixes indicate bytes/sec or bits/sec per use of upper‐ case or lowercase, respectively. Also the p suffix is supported to set the burst size in packets, e.g. isochro‐ nous=2:25p will send two 25 packet bursts every second, or one 25 packet burst every 0.5 seconds.)

--local-only[=1|0] Set 1 to limit traffic to the local network only (through the use of SO_DONTROUTE) set to zero otherwise with op‐ tional override of compile time default (see configure --default-localonly)

--near-congestion[=n] Enable TCP write rate limiting per the sampled RTT. The delay is applied after the -l number of bytes have completed. The optional value is the multiplier to the RTT and defines the time delay. This value defaults to 0.5 if it is not set. Values less than 1 are supported but the value cannot be negative. This is an experimental feature. It is not likely stable on live networks. Suggested use is over controlled test networks.

--no-connect-sync By default, parallel traffic threads (per -P greater than 1) will synchronize after their TCP connects and prior to each sending traffic, i.e. all the threads first complete (or error) the TCP 3WHS before any traffic thread will start sending. This option disables that synchronization such that each traffic thread will start sending immediately after completing its successful connect.

--no-udp-fin Don't perform the UDP final server to client exchange which means there won't be a final server report displayed on the client. All packets per the test will be from the client to the server and no packets should be sent in the other direction. It's highly suggested that -t be set on the server if this option is being used. This is because there will be only one trigger ending packet sent from client to server and if it's lost then the server will continue to run. (Requires ver 2.0.14 or better)

-n, --num n[kmKM] number of bytes to transmit (instead of -t)

--permit-key [=<value>] Set a key value that must match the server's value (also set with --permit-key) in order for the server to accept traffic from the client. TCP only, no UDP support.

--sync-transfer-id Pass the clients' transfer id(s) to the server so both will use the same id in their respective outputs

-r, --tradeoff Do a bidirectional test individually - client-to-server, followed by a reversed test, server-to-client

--tcp-cca Set the congestion control algorithm to be used for TCP connections & exchange with the server (same as --tcp-conges‐ tion)

--tcp-quickack Set TCP_QUICKACK on the socket

--tcp-write-prefetch n[kmKM] Set TCP_NOTSENT_LOWAT on the socket and use event based writes per select() on the socket.

--tcp-write-times Measure the socket write times

-t, --time n|0 time in seconds to transmit traffic, use zero for infinite (default is 10 secs)

--trip-times enable the measurement of end to end write to read latencies (client and server clocks must be synchronized.) See notes about tcp-write-prefetch being enabled.

--txdelay-time time in seconds to hold back or delay after the TCP connect and prior to the socket writes. For UDP it's the delay between the traffic thread starting and the first write.

--txstart-time n.n set the txstart-time to n.n using unix or epoch time format (supports microsecond resolution, e.g 1536014418.123456) An example to delay one second using command substitution is iperf -c 192.168.1.10 --txstart-time $(expr $(date +%s) + 1).$(date +%N)

--udp-l4s run an l4s traffic load (requires a iperf server that supports l4s)

-B, --bind ip | ip:port | ipv6 -V | [ipv6]:port -V bind src ip addr and optional port as the source of traffic (see NOTES)

-F, --fileinput name input the data to be transmitted from a file

-I, --stdin input the data to be transmitted from stdin

-L, --listenport n port to receive bidirectional tests back on

-P, --parallel n number of parallel client threads to run

-R, --reverse reverse the traffic flow (useful for testing through firewalls, see NOTES)

-S, --tos <val> set the socket's IP_TOS value. Versions 2.1.5 or greater will reflect this tos setting back with --reverse or --full-duplex option. (Previous versions won't set tos on the reverse traffic.) Note: use server side --tos-override to override. See NOTES for values.

-T, --ttl n time-to-live, for multicast (default 1)

--working-load[=up|down|bidir][,n] request a concurrent working load, currently TCP stream(s), defaults to full duplex (or bidir) unless the up or down option is provided. The number of TCP streams defaults to 1 and can be changed via the n value, e.g. --work‐ ing-load=down,4 will use four TCP streams from server to the client as the working load. The IP ToS will be BE (0x0) for working load traffic.

--working-load-cca Set the congestion control algorithm to be used for TCP working loads, exchange with the server

-V, --ipv6_domain Set the domain to IPv6 (send packets over IPv6)

-X, --peerdetect run peer version detection prior to traffic.

-Z, --linux-congestion algo set TCP congestion control algorithm (Linux only)

Parameter

limit

Hard limit on the real queue size. When this limit is reached, new packets are dropped. If the value is lowered, packets are dropped so that the new limit is met. Default is 10000 packets.

flow_limit

Hard limit on the maximum number of packets queued per flow. Default value is 100.

Use of TCP_TX_DELAY option will increase number of skbs in FQ qdisc, so packets would be dropped if any of the previous limit is hit. Using big delays might very well trigger old bugs in TSO auto defer logic and/or sndbuf limited detection.

Fast Sampling: Use ./configure --enable-fastsampling and then compile from source to enable four digit (e.g. 1.0000) preci‐ sion in reports' timestamps. Useful for sub-millisecond sampling.

Umgebungsvariablen

Exit-Status

Anwendung

TCP tests (client)

iperf -c <host> -e -i 1
------------------------------------------------------------
Client connecting to 192.168.1.35, TCP port 5001 with pid 256370 (1/0 flows/load)
Write buffer size: 131072 Byte
TCP congestion control using cubic
TOS set to 0x0 (dscp=0,ecn=0) (Nagle on)
TCP window size:  100 MByte (default)
------------------------------------------------------------
[   1]  local  192.168.1.103%enp4s0  port  41024 connected with 192.168.1.35 port 5001 (sock=3) (icwnd/mss/irtt=14/1448/158)
(ct=0.21 ms) on 2024-03-26 10:48:47.867 (PDT)
[ ID] Interval        Transfer    Bandwidth       Write/Err  Rtry     InF(pkts)/Cwnd(pkts)/RTT(var)        NetPwr
[  1] 0.00-1.00 sec   201 MBytes  1.68 Gbits/sec  1605/0        73     1531K(1083)/1566K(1108)/13336(112) us  15775
[  1] 1.00-2.00 sec   101 MBytes   846 Mbits/sec  807/0         0     1670K(1181)/1689K(1195)/14429(83) us  7331
[  1] 2.00-3.00 sec   101 MBytes   847 Mbits/sec  808/0         0     1790K(1266)/1790K(1266)/15325(97) us  6911
[  1] 3.00-4.00 sec   134 MBytes  1.13 Gbits/sec  1075/0         0     1858K(1314)/1892K(1338)/16188(99) us  8704
[  1] 4.00-5.00 sec   101 MBytes   846 Mbits/sec  807/0         1     1350K(955)/1370K(969)/11620(98) us  9103
[  1] 5.00-6.00 sec   121 MBytes  1.01 Gbits/sec  966/0         0     1422K(1006)/1453K(1028)/12405(118) us  10207
[  1] 6.00-7.00 sec   115 MBytes   962 Mbits/sec  917/0         0     1534K(1085)/1537K(1087)/13135(105) us  9151
[  1] 7.00-8.00 sec   101 MBytes   844 Mbits/sec  805/0         0     1532K(1084)/1580K(1118)/13582(136) us  7769
[  1] 8.00-9.00 sec   134 MBytes  1.13 Gbits/sec  1076/0         0     1603K(1134)/1619K(1145)/13858(105) us  10177
[  1] 9.00-10.00 sec   101 MBytes   846 Mbits/sec  807/0         0     1602K(1133)/1650K(1167)/14113(105) us  7495
[  1] 10.00-10.78 sec   128 KBytes  1.34 Mbits/sec  1/0         0        0K(0)/1681K(1189)/14424(111) us  11.64
[  1] 0.00-10.78 sec  1.18 GBytes   941 Mbits/sec  9674/0        74        0K(0)/1681K(1189)/14424(111) us  8154

where (per -e,)
ct= TCP connect time (or three way handshake time 3WHS)
Write/Err Total number of successful socket writes. Total number of non-fatal socket write errors
Rtry Total number of TCP retries
Inf(pkts)/Cwnd(pkts)/RTT(var) (*nix only) TCP bytes and packets inflight, congestion window bytes  and  packets,  and
round  trip time and variance (sampled where NA indicates no value). Inflight is in units of Kbytes and packets where
packets_in_flight   =   (tcp_info_buf.tcpi_unacked   -   tcp_info_buf.tcpi_sacked    -    tcp_info_buf.tcpi_lost    +
tcp_info_buf.tcpi_retrans)  RTT  (var)  is  the  sampled  RTT  variance. All stats taken from tcp_info or tcp_connec‐
tion_info and sampled per the -i reportting interval
NetPwr (*nix only) Network power defined as (throughput / RTT)
iperf -c host.domain.com -i 1 --bounceback --permit-key=mytest --hide-ips
------------------------------------------------------------
Client connecting to (**hidden**), TCP port 5001
Bursting:  100 Byte writes 10 times every 1.00 second(s)
Bounce-back test (size= 100 Byte) (server hold req=0 usecs)
TCP window size: 16.0 KByte (default)
------------------------------------------------------------
[mytest(1)]   local   *.*.*.96   port   38044   connected   with   *.*.*.123   port    5001    (bb    len/hold=100/0)
(icwnd/mss/irtt=14/1448/10605)
[ ID] Interval        Transfer    Bandwidth         BB cnt=avg/min/max/stdev         Rtry  Cwnd/RTT    RPS
[mytest(1)]  0.00-1.00  sec  1.95 KBytes  16.0 Kbits/sec    10=11.949/9.662/19.597/3.127 ms    0   14K/10930 us    83
rps
[mytest(1)] 1.00-2.00 sec  1.95 KBytes  16.0 Kbits/sec    10=10.004/9.651/10.322/0.232 ms    0   14K/10244  us     99
rps
[mytest(1)]  2.00-3.00  sec  1.95 KBytes  16.0 Kbits/sec    10=10.582/9.720/14.831/1.573 ms    0   14K/10352 us    94
rps
[mytest(1)] 3.00-4.00 sec  1.95 KBytes  16.0 Kbits/sec    10=11.303/9.940/15.114/2.026 ms    0   14K/10832  us     88
rps
[mytest(1)]  4.00-5.00  sec  1.95 KBytes  16.0 Kbits/sec    10=11.148/9.671/14.803/1.837 ms    0   14K/10858 us    89
rps
[mytest(1)] 5.00-6.00 sec  1.95 KBytes  16.0 Kbits/sec    10=10.207/9.695/10.729/0.356 ms    0   14K/10390  us     97
rps
[mytest(1)]  6.00-7.00  sec  1.95 KBytes  16.0 Kbits/sec    10=10.871/9.770/14.387/1.547 ms    0   14K/10660 us    91
rps
[mytest(1)] 7.00-8.00 sec  1.95 KBytes  16.0 Kbits/sec    10=11.224/9.760/14.993/1.837 ms    0   14K/11027  us     89
rps
[mytest(1)]  8.00-9.00  sec  1.95 KBytes  16.0 Kbits/sec    10=10.719/9.887/14.553/1.455 ms    0   14K/10620 us    93
rps
[mytest(1)] 9.00-10.00 sec  1.95 KBytes  16.0 Kbits/sec    10=10.775/9.689/14.746/1.562 ms    0   14K/10596 us     92
rps
[mytest(1)] 0.00-10.02 sec  19.5 KBytes  16.0 Kbits/sec    100=10.878/9.651/19.597/1.743 ms    0   14K/11676 us    91
rps
[   1] 0.00-10.02 sec BB8(f)-PDF: bin(w=100us): cnt(100)=97: 5,98: 8,99: 10,100: 8,101: 12,102: 10,103: 6,104: 7,105:
2,106: 2,107: 3,108: 3,109: 2,110: 1,114: 1,115: 1,118: 1,120: 2,121:  1,124:  1,125:  1,128:  1,140:  1,143:  1,144:
1,146: 2,148: 1,149: 2,150: 1,151: 1,152: 1,196: 1 (5.00/95.00/99.7%=97/149/196,Outliers=0,obl/obu=0/0)

where  BB  cnt=avg/min/max/stdev Count of bouncebacks, average time, minimum time, maximum time, standard deviation units of
ms
Rtry Total number of TCP retries
Cwnd/RTT (*nix only) TCP congestion window and round trip time (sampled where NA indicates no value)
RPS Responses per second


TCP tests (server)

iperf -s -e -i 1 -l 8K
------------------------------------------------------------
Server listening on TCP port 5001 with pid 13430
Read buffer size: 8.00 KByte
TCP window size: 85.3 KByte (default)
------------------------------------------------------------
[  4] local 45.33.58.123 port 5001 connected with 45.56.85.133 port 49960
[ ID] Interval        Transfer    Bandwidth       Reads   Dist(bin=1.0K)
[  4] 0.00-1.00 sec   124 MBytes  1.04 Gbits/sec  22249    798:2637:2061:767:2165:1563:589:11669
[  4] 1.00-2.00 sec   136 MBytes  1.14 Gbits/sec  24780    946:3227:2227:790:2427:1888:641:12634
[  4] 2.00-3.00 sec   137 MBytes  1.15 Gbits/sec  24484    1047:2686:2218:810:2195:1819:728:12981
[  4] 3.00-4.00 sec   126 MBytes  1.06 Gbits/sec  20812    863:1353:1546:614:1712:1298:547:12879
[  4] 4.00-5.00 sec   117 MBytes   984 Mbits/sec  20266    769:1886:1828:589:1866:1350:476:11502
[  4] 5.00-6.00 sec   143 MBytes  1.20 Gbits/sec  24603    1066:1925:2139:822:2237:1827:744:13843
[  4] 6.00-7.00 sec   126 MBytes  1.06 Gbits/sec  22635    834:2464:2249:724:2269:1646:608:11841
[  4] 7.00-8.00 sec   110 MBytes   921 Mbits/sec  21107    842:2437:2747:592:2871:1903:496:9219
[  4] 8.00-9.00 sec   126 MBytes  1.06 Gbits/sec  22804    1038:1784:2639:656:2738:1927:573:11449
[  4] 9.00-10.00 sec   133 MBytes  1.11 Gbits/sec  23091    1088:1654:2105:710:2333:1928:723:12550
[  4] 0.00-10.02 sec  1.25 GBytes  1.07 Gbits/sec  227306    9316:22088:21792:7096:22893:17193:6138:120790

where (per -e,)
Reads Total number of socket reads
Dist(bin=size) Eight bin histogram of the socket reads returned byte count. Bin width is set per size. Bins are sepa‐
rated by a colon. In the example, the bins are 0-1K, 1K-2K, .., 7K-8K.


TCP tests server with --trip-times on client

iperf -s -i 1 -w 4M
------------------------------------------------------------
Server listening on TCP port 5001
TCP window size: 8.00 MByte (WARNING: requested 4.00 MByte)
------------------------------------------------------------
[  4] local 192.168.1.4%eth0 port 5001 connected with 192.168.1.7 port 44798 (trip-times) (MSS=1448) (peer 2.0.14-alpha)
[ ID] Interval        Transfer    Bandwidth    Burst Latency avg/min/max/stdev (cnt/size) inP NetPwr  Reads=Dist
[  4]  0.00-1.00  sec   19.0  MBytes    159  Mbits/sec   52.314/10.238/117.155/19.779  ms  (151/131717)  1.05  MByte  380.19
781=306:253:129:48:18:15:8:4
[   4]  1.00-2.00  sec   20.0  MBytes    168  Mbits/sec   53.863/21.264/79.252/12.277  ms  (160/131080)  1.08  MByte  389.38
771=294:236:126:60:18:24:10:3
[  4]  2.00-3.00  sec   18.2  MBytes    153  Mbits/sec   58.718/22.000/137.944/20.397  ms  (146/130964)  1.06  MByte  325.64
732=299:231:98:52:18:19:10:5
[   4]  3.00-4.00  sec   19.7  MBytes    165  Mbits/sec   50.448/  8.921/82.728/14.627  ms  (158/130588)   997  KByte 409.00
780=300:255:121:58:15:18:7:6
[  4]  4.00-5.00  sec   18.8  MBytes    158  Mbits/sec   53.826/11.169/115.316/15.541  ms  (150/131420)  1.02  MByte  366.24
761=302:226:134:52:22:17:7:1
[   4]  5.00-6.00  sec   19.5  MBytes    164  Mbits/sec   50.943/11.922/76.134/14.053  ms  (156/131276)  1.03  MByte  402.00
759=273:246:149:45:16:18:4:8
[  4]  6.00-7.00  sec   18.5  MBytes    155  Mbits/sec   57.643/10.039/127.850/18.950  ms  (148/130926)  1.05  MByte  336.16
710=262:228:133:37:16:20:8:6
[   4]  7.00-8.00  sec   19.6  MBytes    165  Mbits/sec   52.498/12.900/77.045/12.979  ms  (157/131003)  1.00  MByte  391.78
742=288:200:135:68:16:23:4:8
[  4] 8.00-9.00  sec   18.0  MBytes    151  Mbits/sec   58.370/  8.026/150.243/21.445  ms  (144/131255)  1.06  MByte  323.81
716=268:241:108:51:20:17:8:3
[   4]  9.00-10.00  sec   18.4  MBytes    154  Mbits/sec   56.112/12.419/79.790/13.668  ms  (147/131194)  1.05  MByte 343.70
822=330:303:120:26:16:14:9:4
[   4]  10.00-10.06  sec   1.03  MBytes    146  Mbits/sec   69.880/45.175/78.754/10.823  ms  (9/119632)  1.74  MByte  260.40
62=26:30:5:1:0:0:0:0
[   4]  0.00-10.06  sec    191  MBytes    159  Mbits/sec   54.183/  8.026/150.243/16.781  ms (1526/131072) 1.03 MByte 366.98
7636=2948:2449:1258:498:175:185:75:48

where (per -e,)
Burst Latency One way TCP write() to read() latency in mean/minimum/maximum/standard deviation format (Note: requires
the client's and server's system clocks to be synchronized to a common reference, e.g. using precision time  protocol
PTP. A GPS disciplined OCXO is a recommended reference.)
cnt Number of completed bursts received and used for the burst latency calculations
size Average burst size in bytes (computed average and estimate only)
inP  inP,  short for in progress, is the average number of bytes in progress or in flight. This is taken from the ap‐
plication level write to read perspective. Note this is a mean value. The parenthesis value is the standard deviation
from the mean.  (Requires --trip-times on client. See Little's law in NOTES.)
NetPwr Network power defined as (throughput / one way latency)

TCP tests with one way delay sync check -X and --trip-times on the client

iperf -c 192.168.1.4 -X -e --trip-times -i 1 -t 2
------------------------------------------------------------
Client connecting to 192.168.1.4, TCP port 5001 with pid 16762 (1 flows)
Write buffer size: 131072 Byte
TCP window size: 85.0 KByte (default)
------------------------------------------------------------
[ 1] Clock sync check (ms): RTT/Half=(3.361/1.680) OWD-send/ack/asym=(2.246/1.115/1.131)
[  1] local 192.168.1.1%ap0 port  47466  connected  with  192.168.1.4  port  5001  (MSS=1448)  (trip-times)  (sock=3)  (peer
2.1.4-master)
[ ID] Interval        Transfer    Bandwidth       Write/Err  Rtry     Cwnd/RTT        NetPwr
[  1] 0.00-1.00 sec  9.50 MBytes  79.7 Mbits/sec  77/0          0     2309K/113914 us  87
[  1] 1.00-2.00 sec  7.12 MBytes  59.8 Mbits/sec  57/0          0     2492K/126113 us  59
[  1] 2.00-2.42 sec   128 KBytes  2.47 Mbits/sec  2/0          0     2492K/126113 us  2
[  1] 0.00-2.42 sec  16.8 MBytes  58.0 Mbits/sec  136/0          0     2492K/126113 us  57

UDP tests (client)

iperf -c <host> -e -i 1 -u -b 10m
------------------------------------------------------------
Client connecting to <host>, UDP port 5001 with pid 5169
Sending 1470 byte datagrams, IPG target: 1176.00 us (kalman adjust)
UDP buffer size:  208 KByte (default)
------------------------------------------------------------
[  3] local 45.56.85.133 port 32943 connected with 45.33.58.123 port 5001
[ ID] Interval        Transfer     Bandwidth      Write/Err  PPS
[  3] 0.00-1.00 sec  1.19 MBytes  10.0 Mbits/sec  852/0      851 pps
[  3] 1.00-2.00 sec  1.19 MBytes  10.0 Mbits/sec  850/0      850 pps
[  3] 2.00-3.00 sec  1.19 MBytes  10.0 Mbits/sec  850/0      850 pps
[  3] 3.00-4.00 sec  1.19 MBytes  10.0 Mbits/sec  851/0      850 pps
[  3] 4.00-5.00 sec  1.19 MBytes  10.0 Mbits/sec  850/0      850 pps
[  3] 5.00-6.00 sec  1.19 MBytes  10.0 Mbits/sec  850/0      850 pps
[  3] 6.00-7.00 sec  1.19 MBytes  10.0 Mbits/sec  851/0      850 pps
[  3] 7.00-8.00 sec  1.19 MBytes  10.0 Mbits/sec  850/0      850 pps
[  3] 8.00-9.00 sec  1.19 MBytes  10.0 Mbits/sec  851/0      850 pps
[  3] 0.00-10.00 sec  11.9 MBytes  10.0 Mbits/sec  8504/0      850 pps
[  3] Sent 8504 datagrams
[  3] Server Report:
[   3]  0.00-10.00  sec   11.9  MBytes   10.0  Mbits/sec    0.047 ms    0/ 8504 (0%)  0.537/ 0.392/23.657/ 0.497 ms  850 pps
2329.37

where (per -e,)
Write/Err Total number of successful socket writes. Total number of non-fatal socket write errors
PPS Transmit packet rate in packets per second


UDP tests (server)

iperf -s -i 1 -w 4M -u
------------------------------------------------------------
Server listening on UDP port 5001
Receiving 1470 byte datagrams
UDP buffer size: 8.00 MByte (WARNING: requested 4.00 MByte)
------------------------------------------------------------
[  3] local 192.168.1.4 port  5001  connected  with  192.168.1.1  port  60027  (WARN:  winsize=8.00  MByte  req=4.00  MByte)
(trip-times) (0.0) (peer 2.0.14-alpha)
[ ID] Interval        Transfer     Bandwidth        Jitter   Lost/Total  Latency avg/min/max/stdev PPS  inP NetPwr
[   3] 0.00-1.00 sec  44.5 MBytes   373 Mbits/sec   0.071 ms 52198/83938 (62%) 75.185/ 2.367/85.189/14.430 ms 31854 pps 3.64
MByte 620.58
[  3] 1.00-2.00 sec  44.8 MBytes   376 Mbits/sec   0.015 ms 59549/143701 (41%) 79.609/75.603/85.757/ 1.454 ms 31954 pps 3.56
MByte 590.04
[  3] 2.00-3.00 sec  44.5 MBytes   373 Mbits/sec   0.017 ms 59494/202975 (29%) 80.006/75.951/88.198/ 1.638 ms 31733 pps 3.56
MByte 583.07
[  3] 3.00-4.00 sec  44.5 MBytes   373 Mbits/sec   0.019 ms 59586/262562 (23%) 79.939/75.667/83.857/ 1.145 ms 31767 pps 3.56
MByte 583.57
[  3] 4.00-5.00 sec  44.5 MBytes   373 Mbits/sec   0.081 ms 59612/322196 (19%) 79.882/75.400/86.618/ 1.666 ms 31755 pps 3.55
MByte 584.40
[  3] 5.00-6.00 sec  44.7 MBytes   375 Mbits/sec   0.064 ms 59571/381918 (16%) 79.767/75.571/85.339/ 1.556 ms 31879 pps 3.56
MByte 588.02
[  3] 6.00-7.00 sec  44.6 MBytes   374 Mbits/sec   0.041 ms 58990/440820 (13%) 79.722/75.662/85.938/ 1.087 ms 31820 pps 3.58
MByte 586.73
[  3] 7.00-8.00 sec  44.7 MBytes   375 Mbits/sec   0.027 ms 59679/500548 (12%) 79.745/75.704/84.731/ 1.094 ms 31869 pps 3.55
MByte 587.46
[  3] 8.00-9.00 sec  44.3 MBytes   371 Mbits/sec   0.078 ms 59230/559499 (11%) 80.346/75.514/94.293/ 2.858 ms 31590 pps 3.58
MByte 577.97
[  3] 9.00-10.00 sec  44.4 MBytes   373 Mbits/sec   0.073 ms 58782/618394 (9.5%) 79.125/75.511/93.638/ 1.643  ms  31702  pps
3.55 MByte 588.99
[  3] 10.00-10.08 sec  3.53 MBytes   367 Mbits/sec   0.129 ms 6026/595236 (1%) 94.967/80.709/99.685/ 3.560 ms 31107 pps 3.58
MByte 483.12
[   3]  0.00-10.08  sec   449 MBytes   374 Mbits/sec   0.129 ms 592717/913046 (65%) 79.453/ 2.367/99.685/ 5.200 ms 31776 pps
(null) 587.91

where (per -e,)
Latency End to end latency in  mean/minimum/maximum/standard  deviation  format  (Note:  requires  the  client's  and
server's system clocks to be synchronized to a common reference, e.g. using precision time protocol PTP. A GPS disci‐
plined OCXO is a recommended reference.)
PPS Received packet rate in packets per second
inP inP, short for in progress, is the average number of bytes in progress or in flight. This is taken from an appli‐
cation write to read perspective. (Requires --trip-times on client. See Little's law in NOTES.)
NetPwr Network power defined as (throughput / latency)

Isochronous UDP tests (client)

iperf -c 192.168.100.33 -u -e -i 1 --isochronous=60:100m,10m --realtime
------------------------------------------------------------
Client connecting to 192.168.100.33, UDP port 5001 with pid 14971
UDP isochronous: 60 frames/sec mean= 100 Mbit/s, stddev=10.0 Mbit/s, Period/IPG=16.67/0.005 ms
UDP buffer size:  208 KByte (default)
------------------------------------------------------------
[  3] local 192.168.100.76 port 42928 connected with 192.168.100.33 port 5001
[ ID] Interval        Transfer     Bandwidth      Write/Err  PPS  frames:tx/missed/slips
[  3] 0.00-1.00 sec  12.0 MBytes   101 Mbits/sec  8615/0     8493 pps   62/0/0
[  3] 1.00-2.00 sec  12.0 MBytes   100 Mbits/sec  8556/0     8557 pps   60/0/0
[  3] 2.00-3.00 sec  12.0 MBytes   101 Mbits/sec  8586/0     8586 pps   60/0/0
[  3] 3.00-4.00 sec  12.1 MBytes   102 Mbits/sec  8687/0     8687 pps   60/0/0
[  3] 4.00-5.00 sec  11.8 MBytes  99.2 Mbits/sec  8468/0     8468 pps   60/0/0
[  3] 5.00-6.00 sec  11.9 MBytes  99.8 Mbits/sec  8519/0     8520 pps   60/0/0
[  3] 6.00-7.00 sec  12.1 MBytes   102 Mbits/sec  8694/0     8694 pps   60/0/0
[  3] 7.00-8.00 sec  12.1 MBytes   102 Mbits/sec  8692/0     8692 pps   60/0/0
[  3] 8.00-9.00 sec  11.9 MBytes   100 Mbits/sec  8537/0     8537 pps   60/0/0
[  3] 9.00-10.00 sec  11.8 MBytes  99.0 Mbits/sec  8450/0     8450 pps   60/0/0
[  3] 0.00-10.01 sec   120 MBytes   100 Mbits/sec  85867/0     8574 pps  602/0/0
[  3] Sent 85867 datagrams
[  3] Server Report:
[   3]  0.00-9.98  sec    120  MBytes    101 Mbits/sec   0.009 ms  196/85867 (0.23%)  0.665/ 0.083/ 1.318/ 0.174 ms 8605 pps
18903.85

where (per -e,)
frames:tx/missed/slips Total number of isochronous frames or bursts. Total number of frame ids not sent. Total number
of frame slips

Isochronous UDP tests (server)

iperf -s -e -u --udp-histogram=100u,2000 --realtime
------------------------------------------------------------
Server listening on UDP port 5001 with pid 5175
Receiving 1470 byte datagrams
UDP buffer size:  208 KByte (default)
------------------------------------------------------------
[  3] local 192.168.100.33 port 5001 connected with 192.168.100.76 port 42928 isoch (peer 2.0.13-alpha)
[ ID] Interval        Transfer     Bandwidth        Jitter   Lost/Total  Latency avg/min/max/stdev PPS  NetPwr  Frames/Lost
[  3] 0.00-9.98 sec   120 MBytes   101 Mbits/sec   0.010 ms  196/85867 (0.23%)  0.665/  0.083/  1.318/  0.284  ms  8585  pps
18903.85  601/1
[   3]  0.00-9.98  sec  T8(f)-PDF:  bin(w=100us):  cnt(85671)= 1:2,2:844,3: 10034,4: 8493,5: 8967,6: 8733,7: 8823,8: 9023,9:
8901,10: 8816,11: 7730,12: 4563,13: 741,14:1 (5.00/95.00%=3/12,Outliers=0,obl/obu=0/0)
[  3] 0.00-9.98 sec F8(f)-PDF: bin(w=100us): cnt(598)= 15:2,16:1,17: 27,18: 68,19: 125,20:  136,21:  103,22:  83,23:  22,24:
23,25: 5,26: 3 (5.00/95.00%=17/24,Outliers=0,obl/obu=0/0)

where, Frames/lost Total number of frames (or bursts) received. Total number of bursts lost or error-ed
T8-PDF(f) Latency histogram for packets
F8-PDF(f) Latency histogram for frames


Hinweise

Numerische Optionen

Einige numerische Optionen unterstützen Formatzeichen pro '<value>c' (z. B. 10M), wobei die c-Formatzeichen k, m, g, K, M, G sind. Kleinbuchstaben-Formatzeichen basieren auf 10^3 und Großbuchstaben auf 2^n, z. B. 1k = 1000, 1K = 1024, 1m = 1.000.000 und 1M = 1.048.576

Ratenbegrenzung

Die Option -b unterstützt die Begrenzung der Lese- und Schreibrate auf Anwendungsebene. Die Option -b auf dem Client unterstützt auch variable angebotene Lasten über das Format <Mittelwert>,<Standardabweichung>, z. B. -b 100m,10m. Die verwendete Verteilung ist logarithmisch normal. Ähnliches gilt für die isochrone Option. Die Option -b auf dem Server begrenzt die Lesevorgänge. Socket-basierte Taktung wird auch mit der langen Option --fq-rate unterstützt. Dies funktioniert auch mit den Optionen --reverse und --full-duplex.

IP tos und dscp

Gibt die Dienstart oder die DSCP-Klasse für Verbindungen an. Akzeptierte Werte sind af11, af12, af13, af21, af22, af23, af31, af32, af33, af41, af42, af43, cs0, cs1, cs2, cs3, cs4, cs5, cs6, cs7, ef, le, nqb, nqb2, ac_be, ac_bk, ac_vi, ac_vo, lowdelay, throughput, reliability, einen numerischen Wert oder keinen Wert, um die Standardeinstellung des Betriebssystems zu verwenden. Die ac_xx-Werte sind die vier in WMM für Wi-Fi definierten Zugriffskategorien und sie sind Aliase für DSCP-Werte, die den entsprechenden ACs zugeordnet werden, unter der Annahme, dass das Gerät die in IETF RFC 8325 angegebene DSCP-zu-UP-Zuordnungstabelle verwendet.

Das TOS-Byte kann wie folgt festgelegt werden: --dscp auf dem Client --tos oder -S auf dem Client oder Server, wobei die serverseitige Einstellung Einschränkungen unterliegt (siehe nächster Punkt) --tos-override für serverseitigen umgekehrten Datenverkehr (Anwendungsfall: Bleichen des Rückpfads)

Der --dscp-Wert auf dem Client ist lediglich eine Annehmlichkeit, da der Benutzer die sechs Bits des DSCP-Felds festlegen kann, anstatt das TOS-Byte festzulegen. Mit der Option --tos-override kann man die reflektierte TOS-Funktion von APs testen. In diesem Fall bleicht das Netzwerk die clientseitige TOS-Einstellung aus und der Rückverkehr hat dann keine TOS-Einstellung. Vom AP wird erwartet, dass er die TOS des Upstream-Verkehrs auf den Rückverkehr anwendet. Der Anwendungsfall ist, dass die Option --tos-override den Wert Null hat und das Ausbleichen des TOS-Bytes durch das Netzwerk simuliert. Wenn keine --tos-Einstellung vorhanden ist, wird setsockopt nie aufgerufen und die Standardwerte werden verwendet.

--trip-times Die Option --trip-times aktiviert viele One Way Delay (OWD)-Metriken. Beachten Sie auch, dass die Verwendung von --trip-times auf einem TCP-Client dazu führt, dass --tcp-write-prefetch auf einen kleinen Wert gesetzt wird, wenn tcp-write-prefetch nicht ebenfalls gesetzt wurde. Dies geschieht, um die sendeseitige Bloat-Latenz zu reduzieren (die nicht mit der netzwerkbedingten Latenz zusammenhängt). Setzen Sie --tcp-write-prefetch auf Null, um dies zu deaktivieren (was TCP_NOTSENT_LOWAT deaktiviert) und sendeseitiges Bloat zu ermöglichen.

Synchronisierte Uhren

Die Option --trip-times gibt an, dass die Uhren des Clients und des Servers auf eine gemeinsame Referenz synchronisiert sind. Hierfür werden üblicherweise das Network Time Protocol (NTP) oder das Precision Time Protocol (PTP) verwendet. Der Fehler der Referenzuhr(en) und die Synchronisierungsprotokolle beeinflussen die Genauigkeit von End-to-End-Latenzmessungen. Siehe Abschnitt "Bounceback-HINWEISE" zu nicht synchronisierten Uhren

Histogramme und nichtparametrische Statistiken

Die Option --histograms liefert die Rohdaten, bei denen nichts gemittelt wird. Dies ist nützlich für nichtparametrische Verteilungen, z. B. Latenz. Die Standardausgabe verwendet den zentralen Grenzwertsatz, um Durchschnitt, Minimum, Maximum und Variation zu erzeugen. Dabei gehen Informationen verloren, wenn die zugrunde liegende Verteilung nicht gaußförmig ist. Histogramme werden unterstützt, sodass diese Informationen verfügbar sind.

Interpretation der Histogrammausgabe

Nachfolgend finden Sie ein Beispiel für ein Bounceback-Histogramm und dessen Interpretation

[ 1] 0,00-5,10 Sek. BB8-PDF: bin(w=100us): cnt(50)=35: 1,37: 1,39: 1,40: 3,41: 4,42: 1,43: 1,52: 1,57: 1,65: 1,68: 1,69: 1,70: 1,72: 2,74: 1,75: 5,78: 1,79: 2,80: 4,81: 3,82: 1,83: 1,88: 2,90: 2,92: 1,94: 1,117: 1,126: 1,369: 1,1000: 1,1922: 1,3710: 1 (5,00/95,00/99,7 %=39/1000/3710, Ausreißer=4, obl/obu=0/0)

wobei [ 1] die Verkehrsthread-Nummer 0,00–5,10 Sek. Das Zeitintervall des Histogramms BB8-PDF BB8 ist der Name des Histogramms und die PDF gibt eine Histogramm-Rohausgabe an. bin(w=100us) gibt die Binbreite an. Die Binbreite dieses Histogramms beträgt 100 Mikrosekunden. cnt(50) gibt die Gesamtzahl der Stichproben im Histogramm an. Dieses Histogramm enthält 50 Stichproben. 35:1 gibt die Nummer des Intervalls und anschließend die Anzahl der Stichproben in diesem Intervall an. Intervall 35 mit einer Intervallbreite von 100 us liegt zwischen 3,4 ms und 3,5 ms, und es gab eine Stichprobe, die dort gelandet ist 5,00/95,00/99,7 % = 39/1000/3710 liefert die Konfidenzintervalle der Klasse (gemäß der integrierten kumulativen Verteilungsfunktion). 5 % landeten in 3,9 ms oder besser (die Rückrufklassenanzahl wird mit der Klassenbreite multipliziert). 95 % landeten in 10 ms oder besser. 99,7 % oder 3 Standardabweichungen landeten in 37,1 ms oder besser. Ausreißer=4 liefert die Ausreißerzahl, ähnlich wie 3IQR (3-facher Interquartilbereich), verwendet jedoch 10 % und 90 % für den inneren und äußeren Zaunpfosten und dann das Dreifache davon für die Ausreißererkennung. obl/obu=0/0 außerhalb der Grenzen unten und außerhalb der Bänder oben, gibt die Anzahl der Stichproben an, die nicht gebündelt werden konnten, weil der Wert außerhalb aller möglichen Bins lag

Die Bindung erfolgt auf der logischen Ebene von Port und IP-Adresse (oder Schicht 3) unter Verwendung der Option -B und eines Doppelpunkts als Trennzeichen zwischen Port und IP-Adresse. Die Bindung auf der Geräteebene (oder Schicht 2) erfordert das Prozentzeichen (%) als Trennzeichen (sowohl für den Client als auch für den Server). Ein Beispiel für den Quellport und die IP-Adresse lautet -B 192.168.1.1:6001. Um nur den Quellport zu binden und das Betriebssystem die Quell-IP-Adresse auswählen zu lassen, verwenden Sie 0.0.0.0, z. B. -B 0.0.0.0:6001. Auf dem Client wirkt sich die Option -B auf den Systemaufruf bind(2) aus und legt die Quell-IP-Adresse und den Quellport fest, z. B. iperf -c <host> -B 192.168.100.2:6002. Dies steuert die Quellwerte des Pakets, aber nicht das Routing. Dies kann verwirrend sein, da eine Routing- oder Gerätesuche möglicherweise nicht die des Geräts mit der konfigurierten Quell-IP ist. Wenn beispielsweise die IP-Adresse von eth0 für -B verwendet wird und die Routing-Tabelle für die Ziel-IP-Adresse die Ausgangsschnittstelle als eth1 auflöst, sendet der Host das Paket über das Gerät eth1, während er die Quell-IP-Adresse von eth0 im Paket verwendet. Um die physische Ausgabeschnittstelle zu beeinflussen (z. B. Dual-Homing-Systeme), verwenden Sie entweder -c <host>%<dev> (erfordert root), wodurch diese Host-Routentabellensuche umgangen wird, oder konfigurieren Sie das Richtlinienrouting für jede -B-Quelladresse und legen Sie die Ausgabeschnittstelle in den Richtlinienrouten entsprechend fest. Auf dem Server oder beim Empfang werden nur Pakete empfangen, die für die -B-IP-Adresse bestimmt sind. Dies ist auch für Multicast nützlich. Beispielsweise akzeptiert iperf -s -B 224.0.0.1%eth0 nur IP-Multicast-Pakete mit der Ziel-IP 224.0.0.1, die auf der eth0-Schnittstelle empfangen werden, während iperf -s -B 224.0.0.1 diese Pakete auf jeder Schnittstelle empfängt. Schließlich ist der Gerätespezifizierer für v6 link-local erforderlich, z. B. -c [v6addr]%<dev> -V, um die Ausgabeschnittstelle auszuwählen.

Reverse, Full-Duplex, Dualtest (-d) und Tradeoff (-r)

Die Optionen --reverse (-R) und --full-duplex können im Vergleich zu den älteren Optionen --dualtest (-d) und --tradeoff (-r) verwirrend sein. Die neueren Optionen --reverse und --full-duplex öffnen nur einen Socket und lesen und schreiben in denselben Socket-Deskriptor, d. h. sie verwenden den Socket im Vollduplexmodus. Die älteren Optionen -d und -r öffnen zweite Sockets in der entgegengesetzten Richtung und verwenden keinen Socket im Vollduplexmodus. Beachten Sie, dass Vollduplex für den Socket und nicht für die Netzwerkgeräte gilt und dass Vollduplex-Sockets von den Betriebssystemen unterstützt werden, unabhängig davon, ob ein zugrunde liegendes Netzwerk Vollduplex-Übertragung und -Empfang unterstützt. Es wird empfohlen, --reverse zu verwenden, wenn Sie über eine NAT-Firewall testen möchten (oder -R auf Nicht-Windows-Systemen). Dies gilt für den Rollentausch des Tests nach dem Öffnen des Vollduplex-Sockets. (Hinweis: Firewall-Piercing kann erforderlich sein, um -d und -r zu verwenden, wenn sich ein NAT-Gateway im Pfad befindet.)

Außerdem verhält sich die Einstellung --reverse -b <rate> für TCP und UDP unterschiedlich. Bei TCP wird die Leseseite, d. h. der iperf-Client (Rolle umgekehrt, um als Server zu fungieren) liest vom Vollduplex-Socket. Dies wiederum steuert den Rückverkehr per Standard-TCP-Überlastungssteuerung. Die Option --reverse -b <rate> wird auf die Übertragung angewendet (d. h. die Serverrolle wird umgekehrt, um als Client zu fungieren) für UDP, da es bei UDP keine Flusssteuerung gibt. Es gibt keine Option, um die Schreibvorgänge bei TCP-Tests direkt zu begrenzen, wenn --reverse verwendet wird.

Bounceback Der Bounceback-Test ermöglicht die Messung der Netzwerkreaktionsfähigkeit (die in diesem Test das Gegenteil von Latenz ist). Die Einheiten sind Antworten pro Sekunde oder rps. Latenz ist lediglich eine Verzögerung in Zeiteinheiten. Latenzmetriken erfordern die Kenntnis der Verzögerung dessen, was gemessen wird. Bei Bounceback ist es ein Client-Schreibvorgang, der von einem Server-Lesevorgang gefolgt wird, gefolgt von einem Server-Schreibvorgang und dann einem Client-Lesevorgang. Der ursprüngliche Schreibvorgang wird zurückgesendet. Iperf 2 richtet den Socket mit TCP_NODELAY und möglicherweise TCP_QUICKACK ein (sofern nicht deaktiviert). Der Client sendet einen kleinen Schreibvorgang (standardmäßig 100 Byte, sofern nicht -l festgelegt ist) und gibt einen Lesevorgang aus, der auf die "Rückmeldung" vom Server wartet. Der Server wartet auf einen Lesevorgang und verzögert dann optional, bevor er die Nutzlast zurücksendet. Dies wird so lange wiederholt, bis der Datenverkehr endet. Die Ergebnisse werden in Einheiten von rps und Zeitverzögerungen angezeigt.

Die TCP_QUICKACK-Socket-Option wird während Bounceback-Tests aktiviert, wenn der Bounceback-Hold auf einen Wert ungleich Null gesetzt ist. Die Socket-Option wird nach jedem read() auf dem Server und vor dem Aufruf der Halteverzögerung angewendet. Sie wird auch auf dem Client angewendet. Verwenden Sie --bounceback-no-quickack, damit TCP im Standardmodus gemäß dem Socket ausgeführt wird (was höchstwahrscheinlich bedeutet, dass TCP_QUICKACK deaktiviert ist).

Erkennung nicht synchronisierter Uhren mit --bounceback und --trip-times (Stand: 19. März 2023): Iperf 2 kann erkennen, wenn die Uhren Synchronisationsfehler aufweisen, die größer sind als die Bounceback-RTT. Dies geschieht über den Sendezeitstempel des Clients (Uhr A), den Empfangszeitstempel des Servers (Uhr B) und den endgültigen Empfangszeitstempel des Clients (Uhr A). Die Prüfung, die bei jedem Bounceback durchgeführt wird, lautet write(A) < read(B) < read(A). Dies wird in Bounceback-Tests mit einer leichten Anpassung unterstützt: clock write(A) < clock read(B) < clock read(A) - (clock write(B) - clock read(B)). Alle Zeitstempel werden beim ersten Schreiben oder Lesen (nicht beim Abschluss) erfasst. Die Fehlerausgabe sieht wie unten dargestellt aus und es gibt keine Ausgabe für einen Nullwert.

[ 1] 0,00-10,00 Sek. Anzahl der Taktsynchronisierungsfehler = 100

TCP-Verbindungszeiten

Die TCP-Verbindungszeit (oder Drei-Wege-Handshake) kann auf dem Iperf-Client angezeigt werden, wenn die Option -e (--enhanced) eingestellt ist. Suchen Sie nach ct=<Wert> in der verbundenen Nachricht, z. B. in '[ 3] local 192.168.1.4 port 48736 connected with 192.168.1.1 port 5001 (ct=1.84 ms)' zeigt an, dass der 3WHS 1,84 Millisekunden gedauert hat.

Portbereich Portbereiche werden mit der Bindestrichnotation unterstützt, z. B. 6001-6009. Dies führt zu mehreren Threads, einem pro Port, entweder auf dem Listener/Server oder dem Client. Der Benutzer muss darauf achten, dass die Ports im Portbereich verfügbar sind und nicht bereits vom Betriebssystem verwendet werden. Das -P wird auf dem Client unterstützt und gilt für jeden Zielport innerhalb des Portbereichs. Schließlich kann dies als Workaround für Windows UDP und -P > 1 verwendet werden, da Windows UDP nicht über die Verbindung eines Servers und die fünffache

Berechnung der Pakete pro Sekunde (pps) Die Berechnung der Pakete pro Sekunde erfolgt als Ableitung, d. h. Anzahl der Pakete geteilt durch Zeit. Die Zeit wird vom vorherigen letzten Paket bis zum aktuellen letzten Paket genommen. Es handelt sich nicht um die Zeit des Abtastintervalls. Das letzte Paket kann innerhalb eines Intervalls zu unterschiedlichen Zeiten eintreffen. Das bedeutet, dass pps nicht mit rx Bytes geteilt durch das Sample-Intervall übereinstimmen muss. Außerdem wird bei gesetztem --trip-times die Paketzeit beim Empfang durch die Schreibzeit des Senders festgelegt, sodass pps mit --trip-times die End-to-End-pps angibt. Die RX-pps-Berechnung erfolgt nur auf der Empfangsseite, wenn -e gesetzt ist und --trip-times nicht gesetzt ist.

Das Little'sche Gesetz in der Warteschlangentheorie ist ein Theorem, das die durchschnittliche Anzahl von Elementen (L) in einem stationären Warteschlangensystem basierend auf der durchschnittlichen Wartezeit (W) eines Elements innerhalb eines Systems und der durchschnittlichen Anzahl von Elementen, die pro Zeiteinheit (Lambda) im System ankommen, bestimmt. Mathematisch ausgedrückt ist L = Lambda * W. In der hier verwendeten Form sind die Einheiten Bytes. Die Ankunftsrate wird von den Schreibvorgängen übernommen.

Netzwerkleistung

Die Netzwerkleistungsmetrik (NetPwr) ist experimentell. Es handelt sich um eine Hilfsfunktion, die als Durchsatz/Verzögerung definiert ist. Bei TCP-Übertragungen ist die Verzögerung die RTT-Zeit. Bei TCP-Empfang ist die Verzögerung die Schreib-Lese-Latenz. Bei UDP ist die Verzögerung die Ende/Ende-Latenz. Verwechseln Sie dies nicht mit der physikalischen Definition von Leistung (Delta-Energie/Delta-Zeit), sondern eher mit einem Maß für eine wünschenswerte Eigenschaft geteilt durch eine unerwünschte Eigenschaft. Beachten Sie auch, dass Sie das -i-Intervall mit TCP verwenden müssen, um dies zu erhalten, da dies die RTT-Abtastrate festlegt. Die Metrik ist skaliert, um die Lesbarkeit für Menschen zu verbessern.

Multicast

Iperf 2 unterstützt Multicast mit einigen Einschränkungen. Erstens können Multicast-Streams die Option -P nicht nutzen. Der Server serialisiert Multicast-Streams. Außerdem wird dringend empfohlen, auf einem Server, der für Multicast-Clients verwendet wird, -t zu verwenden. Das liegt daran, dass das einzelne Ende des vom Client an den Server gesendeten Datenpakets verloren gehen kann und es keine redundanten Enden von Datenpaketen gibt. Wenn -t auf dem Server eingestellt wird, wird der Server-Thread beendet, falls dieses Paket tatsächlich verloren geht.

TCP_QUICKACK

Die TCP_QUICKACK-Socket-Option wird nach jedem read() auf dem Server angewendet, sodass TCP-Bestätigungen sofort gesendet werden und nicht möglicherweise verzögert.

TCP_TX_DELAY (--tcp-tx-delay): Iperf 2-Datenströme können verschiedene Verzögerungen einstellen und so reale Bedingungen simulieren. Die Einheiten sind Mikrosekunden. Dies erfordert einen FQ-Paketplaner oder eine EDT-fähige Netzwerkkarte. Beachten Sie, dass die Begrenzungen des FQ-Paketplaners möglicherweise angepasst werden müssen. man tc-fq


Anhang

Siehe auch


Dokumentation

Man-Page
Info-Pages

Links

Projekt

Weblinks