Mandalika's scratchpad | [ Work blog @Oracle | My Music Compositions ] |
Old Posts: 09.04 10.04 11.04 12.04 01.05 02.05 03.05 04.05 05.05 06.05 07.05 08.05 09.05 10.05 11.05 12.05 01.06 02.06 03.06 04.06 05.06 06.06 07.06 08.06 09.06 10.06 11.06 12.06 01.07 02.07 03.07 04.07 05.07 06.07 08.07 09.07 10.07 11.07 12.07 01.08 02.08 03.08 04.08 05.08 06.08 07.08 08.08 09.08 10.08 11.08 12.08 01.09 02.09 03.09 04.09 05.09 06.09 07.09 08.09 09.09 10.09 11.09 12.09 01.10 02.10 03.10 04.10 05.10 06.10 07.10 08.10 09.10 10.10 11.10 12.10 01.11 02.11 03.11 04.11 05.11 07.11 08.11 09.11 10.11 11.11 12.11 01.12 02.12 03.12 04.12 05.12 06.12 07.12 08.12 09.12 10.12 11.12 12.12 01.13 02.13 03.13 04.13 05.13 06.13 07.13 08.13 09.13 10.13 11.13 12.13 01.14 02.14 03.14 04.14 05.14 06.14 07.14 09.14 10.14 11.14 12.14 01.15 02.15 03.15 04.15 06.15 09.15 12.15 01.16 03.16 04.16 05.16 06.16 07.16 08.16 09.16 12.16 01.17 02.17 03.17 04.17 06.17 07.17 08.17 09.17 10.17 12.17 01.18 02.18 03.18 04.18 05.18 06.18 07.18 08.18 09.18 11.18 12.18 01.19 02.19 05.19 06.19 08.19 10.19 11.19 05.20 10.20 11.20 12.20 09.21 11.21 12.22
iperf is a simple, open source tool to measure the network bandwidth. It can test TCP or UDP throughput. Tools like iperf are useful to check the performance of a network real quick, by comparing the achieved bandwidth with the expectation. The example in this blog post is from a Solaris system, but the instructions and testing methodology are applicable on all supported platforms including Linux.
Download the source code from iperf's home page, and build the iperf binary. Those running Solaris 10 or later, can download the pre-built binary (file size: 245K) from this location to give it a quick try (right click and "Save Link As .." or similar option).
Testing methodology:
iperf's network performance measurements are based on the client-server communication model - hence requires establishing both a server and a client. The same iperf binary can be used to run the process in server and client modes.
iperf -s -i <interval>
Option -s
or --server
starts the process in server mode. -i
or --interval
is the sampling interval in seconds.
iperf -n <bytes> -i <interval> -c <ServerIP>
Option -c
or --client
starts the process in client mode. Option -n
or --bytes
specify the number of bytes to transmit in bytes, KB (use suffix K) or MB (use suffix M). -i
or --interval
is the sampling interval in seconds. The last option is the IP address or the hostname of the server to connect to. By default, client connects to the server using TCP. -u
or --udp
switches to UDP.
Check the man page out for the full list of options supported by iperf in client and server modes.
Here is a simple demonstration.
On server node:
iperfserv% dladm show-phys net0 LINK MEDIA STATE SPEED DUPLEX DEVICE net0 Ethernet up 1000 full igb0 iperfserv% ifconfig net0 | grep inet inet 10.129.193.63 netmask ffffff00 broadcast 10.129.193.255 iperfserv% ./iperf -v iperf version 3.0-BETA5 (28 March 2013)SunOS iperfserv 5.11 11.1 sun4v sparc sun4v iperfserv% ./iperf -s -i 1 ----------------------------------------------------------- Server listening on 5201 -----------------------------------------------------------
On client node:
client% dladm show-phys net0 LINK MEDIA STATE SPEED DUPLEX DEVICE net0 Ethernet up 1000 full igb0 client% ifconfig net0 | grep inet inet 10.129.193.151 netmask ffffff00 broadcast 10.129.193.255 client% ./iperf -n 1024M -i 1 -c 10.129.193.63 Connecting to host 10.129.193.63, port 5201 [ 4] local 10.129.193.151 port 63507 connected to 10.129.193.63 port 5201 [ ID] Interval Transfer Bandwidth [ 4] 0.00-1.01 sec 105 MBytes 875 Mbits/sec [ 4] 1.01-2.02 sec 112 MBytes 934 Mbits/sec [ 4] 2.02-3.00 sec 110 MBytes 934 Mbits/sec [...] [ 4] 8.02-9.01 sec 110 MBytes 933 Mbits/sec [ 4] 9.01-9.27 sec 30.0 MBytes 934 Mbits/sec [ ID] Interval Transfer Bandwidth Sent [ 4] 0.00-9.27 sec 1.00 GBytes 927 Mbits/sec Received [ 4] 0.00-9.27 sec 1.00 GBytes 927 Mbits/sec iperf Done.
At the same time, somewhat similar messages are written to stdout on the server node.
iperfserv% ./iperf -s -i 1 ----------------------------------------------------------- Server listening on 5201 ----------------------------------------------------------- Accepted connection from 10.129.193.151, port 33457 [ 5] local 10.129.193.63 port 5201 connected to 10.129.193.151 port 63507 [ ID] Interval Transfer Bandwidth [ 5] 0.00-1.00 sec 104 MBytes 874 Mbits/sec [ 5] 1.00-2.00 sec 111 MBytes 934 Mbits/sec [ 5] 2.00-3.00 sec 111 MBytes 934 Mbits/sec [...] [ ID] Interval Transfer Bandwidth Sent [ 5] 0.00-9.28 sec 1.00 GBytes 927 Mbits/sec Received [ 5] 0.00-9.28 sec 1.00 GBytes 927 Mbits/sec ----------------------------------------------------------- Server listening on 5201 -----------------------------------------------------------
The link speed is specified in Mbps (megabit per second). In the above example, the network link is operating at 1000 Mbps speed, and the achieved bandwidth is 927 Mbps, which is 92.7% of the advertised bandwidth.
Notes:
-p
or --port
option
Labels: bandwidth iperf network solaris
2004-2019 |