iperf命令

Iperf 是一个网络性能测试工具。Iperf可以测试最大TCP和UDP带宽性能,具有多种参数和UDP特性,可以根据需要调整,可以报告带宽、延迟抖动和数据包丢失。
下载地址:https://iperf.fr/iperf-download.php#fedora

用户文档地址:https://iperf.fr/iperf-doc.php

安装iperf:

[root@server-A ~]# rpm -ivh iperf3-3.1.-.fc24.x86_64.rpm
Preparing... ################################# [%]
Updating / installing...
:iperf3-3.1.-.fc24 ################################# [%]
[root@server-A ~]# rpm -ql iperf3
/usr/bin/iperf3
/usr/lib64/libiperf.so.
/usr/lib64/libiperf.so.0.0.
/usr/share/doc/iperf3
/usr/share/doc/iperf3/LICENSE
/usr/share/doc/iperf3/README.md
/usr/share/doc/iperf3/RELEASE_NOTES
/usr/share/man/man1/iperf3..gz
/usr/share/man/man3/libiperf..gz

iperf3选项:

通用选项
命令行选项 描述
-p, --port n 服务器端口供服务器监听,客户端连接。在客户端和服务器端都应该是相同的。默认是5201
--cport n 指定客户端端口的选项。(新iPerf 3.1)
-f, --format [kmKM]
格式化带宽数输出。支持的格式有:
'k' = Kbits/sec 'K' = KBytes/sec
'm' = Mbits/sec 'M' = MBytes/sec
-i, --interval n 设置每次报告之间的时间间隔,单位为秒。如果设置为非零值,就会按照此时间间隔输出测试报告。默认值为零。
-F, --file name 客户端:从文件中读取并写入网络,而不是使用随机数据; 
服务器端:从网络读取并写入文件,而不是将数据丢弃。
-A, --affinity n/n,m-F 如果可能的话,设置CPU关联性(仅为Linux和FreeBSD)。在客户机和服务器上,您都可以使用这个参数的n形式来设置本地关联(在这里n是一个CPU数字)。此外,在客户端,您可以使用n、m的参数形式来覆盖服务器的亲合性。注意,在使用这个特性时,进程只会绑定到一个CPU(而不是一个包含潜在的多个CPU的集合)。
-B, --bind host 绑定到主机一个地址。对于客户端,这设置了出站接口。对于服务器,这将设置传入的接口。只适用于多网卡主机。
-V, --verbose 给更详细的输出
-J, --json 以JSON格式输出
--logfile file 将输出发送到一个日志文件。(新iPerf 3.1)
--d, --debug 显示debug信息
-v, --version 显示版本信息并退出。
-h, --help 显示帮助信息
 
服务器选项
命令行选项 描述
-s, --server 在服务器模式下运行iPerf。(这一次只允许一次iperf连接)
-D, --daemon 在后台运行服务器作为守护进程。
-I, --pidfilefile 使用进程ID编写一个文件,在作为守护进程运行时最有用。(新iPerf 3.1)
 
客户端选项
命令行选项 描述
-c, --client host 在客户端模式下运行iPerf,连接到在主机上运行的iPerf服务器。
--sctp 使用SCTP而不是TCP(Linux、FreeBSD和Solaris)。(新iPerf 3.1)
-u, --udp 使用UDP而不是TCP。参见-b选项。
-b, --bandwidth n[KM] UDP模式使用的带宽,单位bits/sec。此选项与-u选项相关。默认值是1 Mbit/sec。
-t, --time n 设置传输的总时间。Iperf在指定的时间内,重复的发送指定长度的数据包。默认是10秒钟。参考-l与-n选项。
-n, --num n[KM] 传送的缓冲器数量。通常情况,Iperf按照10秒钟发送数据。-n参数跨越此限制,按照指定次数发送指定长度的数据,而不论该操作耗费多少时间。参考-l与-t选项。
-k, --blockcount n[KM] 用于传输的块(数据包)的数量。(而不是-t或-n)也可以看到-t,-l和-n选项
-l, --length n[KM] 设置读写缓冲区的长度。TCP方式默认为8KB,UDP方式默认为1470字节。
-P, --parallel n 线程数。指定客户端与服务端之间使用的线程数。默认是1线程。需要客户端与服务器端同时使用此参数。 
-R, --reverse 以反向模式运行(服务器发送,客户端接收)。
-w, --window n[KM] 将套接字缓冲区大小设置为指定的值。对于TCP,这设置了TCP窗口的大小。
-M, --set-mss n 尝试设置TCP最大段大小(MSS)。MSS通常是MTU-40字节的ip报头。对于以太网,MSS是1460字节(1500字节MTU)。
-N, --no-delay 设置TCP不延迟选项,使Nagle的算法失效。通常情况下,像telnet这样的交互式应用程序通过禁用。
-4, --version4 只使用IPv4。
-6, --version4 o只使用IPv6。
-S, --tos n

用于输出数据包的服务类型。(许多路由器忽略了TOS字段。)您可以使用“0x”前缀指定十六进制值,在八进制中使用“0”前缀,或在十进制中。例如,'0x10'十六进制='020'八进制='16'小数。RFC 1349中指定的图号是:

IPTOS_LOWDELAY     minimize delay        0x10

IPTOS_THROUGHPUT   maximize throughput   0x08

IPTOS_RELIABILITY  maximize reliability  0x04

IPTOS_LOWCOST      minimize cost         0x02

-L, --flowlabel n 设置IPv6流标签(目前仅在Linux上支持)。
-Z, --zerocopy 使用“零拷贝”发送数据的方法,例如sendfile(2),而不是通常的写入(2)。这使用了更少的CPU。
-O, --omit n 忽略测试的前n秒,跳过TCP TCP慢启动周期。
-T, --title str 在每个输出行前面加上这个字符串。
-C, --linux-congestion algo 设置拥塞控制算法(Linux只针对iPerf 3.0、Linux和FreeBSD为iPerf 3.1)。

iperf3实例:

带宽测试通常采用UDP模式,因为能测出极限带宽、时延抖动、丢包率。在进行测试时,首先以链路理论带宽作为数据发送速率进行测试,例如,从客户端到服务器之间的链路的理论带宽为100Mbps,先用-b 100M进行测试,然后根据测试结果(包括实际带宽,时延抖动和丢包率),再以实际带宽作为数据发送速率进行测试,会发现时延抖动和丢包率比第一次好很多,重复测试几次,就能得出稳定的实际带宽。

UDP模式:在client端使用-u选项

server:

[root@server-A ~]# iperf3 -s -V
iperf 3.1.
Linux server-A 3.10.-.el7.x86_64 # SMP Tue Nov :: UTC x86_64
-----------------------------------------------------------
Server listening on
-----------------------------------------------------------
Time: Wed, Sep :: GMT
Accepted connection from 192.168.1.120, port
Cookie: client-B.1505859092.776727.2dfae62a4
[ ] local 192.168.1.130 port connected to 192.168.1.120 port
Starting Test: protocol: UDP, streams, byte blocks, omitting seconds, second test
[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams
[ ] 0.00-1.00 sec KBytes Kbits/sec 1638910.193 ms / (%)
[ ] 1.00-2.00 sec KBytes 1.05 Mbits/sec 583573.766 ms / (%)
[ ] 2.00-2.05 sec 0.00 Bytes 0.00 bits/sec 583573.766 ms / (%)
- - - - - - - - - - - - - - - - - - - - - - - - -
Test Complete. Summary Results:
[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams
[ ] 0.00-2.05 sec 0.00 Bytes 0.00 bits/sec 583573.766 ms / (%)
CPU Utilization: local/receiver 0.0% (0.0%u/0.0%s), remote/sender 0.0% (0.0%u/0.0%s)
iperf 3.1.
Linux server-A 3.10.-.el7.x86_64 # SMP Tue Nov :: UTC x86_64
-----------------------------------------------------------
Server listening on
-----------------------------------------------------------

client:

#设置传输时间为2秒
[root@client-B ~]# iperf3 -c 192.168.1.130 -t  -u
Connecting to host 192.168.1.130, port
[ ] local 192.168.1.120 port connected to 192.168.1.130 port
[ ID] Interval Transfer Bandwidth Total Datagrams
[ ] 0.00-1.01 sec KBytes 1.04 Mbits/sec
[ ] 1.01-2.00 sec KBytes 1.05 Mbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval Transfer Bandwidth Jitter Lost/Total Datagrams
[ ] 0.00-2.00 sec KBytes 1.05 Mbits/sec 583573.766 ms / (%)
[ ] Sent datagrams iperf Done.
#客户端同时向服务器端发起30个连接线程,以5Mbps为数据发送速率。
[root@client-B ~]# iperf3 -u -c 192.168.1.130 -b 5M -P -t
#以100M为数据发送速率,进行上下行带宽测试。 

#上传带宽测试
[root@client-B ~]# iperf3 -u -c 192.168.1.130 -b 100M -t #下载带宽测试,使用-R选项
[root@client-B ~]# iperf3 -u -c 192.168.1.130 -b 100M -R -t

TCP模式:默认使用TCP

server:

[root@server-A ~]# iperf3 -s -V
iperf 3.1.
Linux server-A 3.10.-.el7.x86_64 # SMP Tue Nov :: UTC x86_64
-----------------------------------------------------------
Server listening on
-----------------------------------------------------------
Time: Wed, Sep :: GMT
Accepted connection from 192.168.1.120, port
Cookie: client-B.1505860318.231455.1c28c3a96
TCP MSS: (default)
[ ] local 192.168.1.130 port connected to 192.168.1.120 port
Starting Test: protocol: TCP, streams, byte blocks, omitting seconds, second test
[ ID] Interval Transfer Bandwidth
[ ] 0.00-1.00 sec MBytes 4.18 Gbits/sec
[ ] 1.00-2.00 sec MBytes 4.19 Gbits/sec
[ ] 2.00-2.04 sec 17.8 MBytes 3.79 Gbits/sec
- - - - - - - - - - - - - - - - - - - - - - - - -
Test Complete. Summary Results:
[ ID] Interval Transfer Bandwidth
[ ] 0.00-2.04 sec 0.00 Bytes 0.00 bits/sec sender
[ ] 0.00-2.04 sec MBytes 4.18 Gbits/sec receiver
CPU Utilization: local/receiver 5.4% (0.0%u/5.4%s), remote/sender 0.0% (0.0%u/0.0%s)

client:

#在tcp模式下,客户端到服务器192.168.1.1上传带宽测试,测试时间为60秒。
[root@client-B ~]# iperf3 -c 192.168.1.130 -t
Connecting to host 192.168.1.130, port
[ ] local 192.168.1.120 port connected to 192.168.1.130 port
[ ID] Interval Transfer Bandwidth Retr Cwnd
[ ] 0.00-1.00 sec MBytes 4.17 Gbits/sec 2.03 MBytes
[ ] 1.00-2.00 sec MBytes 3.89 Gbits/sec 2.49 MBytes
[ ] 2.00-3.00 sec MBytes 4.25 Gbits/sec 1.80 MBytes
[ ] 3.00-4.00 sec MBytes 4.47 Gbits/sec 1.88 MBytes
[ ] 4.00-5.00 sec MBytes 4.36 Gbits/sec 1.97 MBytes
[ ] 5.00-6.00 sec MBytes 3.98 Gbits/sec 2.04 MBytes
[ ] 6.00-7.00 sec MBytes 4.36 Gbits/sec 1.48 MBytes
...
- - - - - - - - - - - - - - - - - - - - - - - - -
[ ID] Interval Transfer Bandwidth Retr
[ ] 0.00-7.52 sec 3.69 GBytes 4.22 Gbits/sec sender
[ ] 0.00-7.52 sec 0.00 Bytes 0.00 bits/sec receiver
iperf3: interrupt - the client has terminated
#客户端同时向服务器端发起30个连接线程。
[root@client-B ~]# iperf3 -c 192.168.1.130 -P -t
#进行上下行带宽测试。 

#上传带宽测试
[root@client-B ~]# iperf3 -c 192.168.1.130 -t #下载带宽测试,使用-R选项
[root@client-B ~]# iperf3 -c 192.168.1.130 -R -t

iperf3介绍到此结束;有兴趣的朋友可以看下用户文档,其中也有iperf版本2的详细介绍

***********************************************************

学习永远不晚。——高尔基

***********************************************************

Linux每天一个命令:iperf的更多相关文章

  1. LINUX上一个命令计算PI

    Linux上一个命令计算PI – 笑遍世界 http://smilejay.com/2017/11/calculate-pi-with-linux-command/ [root@d1 goEcho]# ...

  2. Linux每天一个命令:grep

    grep (缩写来自Globally search a Regular Expression and Print) 是一种强大的文本搜索工具,它能使用特定模式匹配(包括正则表达式)搜索文本,并默认输出 ...

  3. Linux每天一个命令:tar

    Linux tar命令简介: tar命令可以为linux的文件和目录创建档案.利用tar,可以为某一特定文件创建档案(备份文件),也可以在档案中改变文件,或者向档案中加入新的文件.tar最初被用来在磁 ...

  4. Linux每天一个命令:cat

    Linux cat命令 命令:cat cat 命令用于连接文件并打印到标准输出设备上. 使用权限 所有使用者 语法格式 cat [-AbeEnstTuv] [--help] [--version] f ...

  5. Linux每天一个命令:nc/ncat

    nmap-ncat.x86_64版nc/ncat nc/ncat所做的就是在两台电脑之间建立链接并返回两个数据流,在这之后所能做的事就看你的想像力了.你能建立一个服务器,传输文件,与朋友聊天,传输流媒 ...

  6. linux 每天一个命令

    Nginx [emerg]: bind() to 0.0.0.0:80 failed (98: Address already in use)  使用命令关闭占用80端口的程序 sudo fuser ...

  7. Linux每天一个命令:iostat

    iostat用于输出CPU和磁盘I/O相关的统计信息 安装Sysstat工具包 centos: yum install sysstat ubuntu: sudo apt-get install sys ...

  8. linux系统及命令学习

    1,基本概念 Shell(命令行):是一个程序,接受键盘输入的命令,并将命令传递给操作系统进行执行. Bash:Bourne Again Shell, 是大多数linux系统分之中所带的一种shell ...

  9. linux常用终端命令(一)终端命令格式(二)文件和目录常用命令

    一.linux终端命令格式 1.终端命令格式 command  [-options]  [parameter] 说明: command :命令名,相应功能的英文单词或单词的缩写 [-options] ...

随机推荐

  1. Java 注解用法详解——@SuppressWarnings

    转自: https://www.cnblogs.com/fsjohnhuang/p/4040785.html Java魔法堂:注解用法详解——@SuppressWarnings   一.前言 编码时我 ...

  2. 3hibernate核心对象关系映射 xxx.hbm.xml

    Hibernate的核心就是对象关系映射: 加载映射文件的两种方式: 第一种:<mapping resource="com/bie/lesson02/crud/po/employee. ...

  3. SQL Server 的 RowGuid/RowGuidCol 是什么意思?

    SQL Server 中设计表时,有个属性叫 RowGuid(用 SQL 时,关键词是 RowGuidCol),这个是什么意思呢?这个是全局唯一标识符,与“标识”不同,标识是只在本表中唯一,全局唯一标 ...

  4. linux 通过 mac地址 查询 ip 和 清除arp 缓存

    问题重述: 今天,突然找不到vm 的ip 了,但是可以从网卡状态上看到其 mac 地址,并且确定主机是启动状态,网络状态良好(后来发现因为子网掩码的问题,导致虚拟机和网关之间不通信,从而导致其他网络的 ...

  5. 乘风破浪:LeetCode真题_029_Divide Two Integers

    乘风破浪:LeetCode真题_029_Divide Two Integers 一.前言     两个整数相除,不能使用乘法除法和取余运算.那么就只能想想移位运算和加减法运算了. 二.Divide T ...

  6. 人工智能——Singleton模式

    上次在状态模式中的设计有一个严重的问题,就是如下: voidCTroll::ChageState(CState* pNewState) {        deletem_pCurrentState; ...

  7. ELK安装过程

    官方安装文档:https://www.elastic.co/guide/en/elasticsearch/reference/current/zip-targz.html 官方硬件和配置项推荐:htt ...

  8. Docker容器学习与分享08

    Docker容器网络 Docker除了默认创建的三种网络外,还可以自定义网络. 首先创建一个bridge类型的网络,使用docker network create命令. [root@promote ~ ...

  9. 【python27】猜随机数的小游戏

    游戏规则: 猜一个随机数,如果猜对了就给出相应的猜成功提示语(自定义文字),如果猜大或者是猜小了,给出对应的提示,但总的猜次数为三次,每猜错一次重新猜时,给用户提示所剩余的猜次数 实现如下: # -* ...

  10. js指定范围随机整数

    js获取指定范围内随机整数,例如 6-10 (m-n) 计算公式: Math.floor(Math.random()*(n-m))+m // 6-10随机数,用循环得出一组测试随机数 var str ...