You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

188 lines
10 KiB

This file contains invisible Unicode characters!

This file contains invisible Unicode characters that may be processed differently from what appears below. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to reveal hidden characters.

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

# **iperf**
## 说明
iperf可以测试TCP和UDP带宽质量。iperf可以测量最大TCP带宽具有多种参数和UDP特性。iperf可以报告带宽延迟抖动和数据包丢失。
利用iperf这一特性可以用来测试一些网络设备如路由器防火墙交换机等的性能
* [iperf3 github](https://github.com/esnet/iperf)
* [perfsonar文档](http://docs.perfsonar.net)
* [public iperf3 server地址](https://iperf.fr)
* [internet2](http://software.internet2.edu)
## 网络吞吐量工具比较
* [iperf2](https://sourceforge.net/projects/iperf2/)
* [iperf3](https://software.es.net/iperf)
* [nuttcp](http://nuttcp.net/)
注意:三个工具都在开发阶段,此处有可能随着时间推移有所变动未及时修改
| | | 工具特征比较 | | |
| :------: | :------: | :------: | :------: | :------: |
| 版本 | iperf2.0.5 | iperf2.0.8 + | iperf3.1.5 + | nuttcp 8.x |
|  多线程 | -P | -P | | |
|  JSON输出 | | | --json | |
|  CSV输出 | -y | -y | | |
| FQ-based pacing | | | --fq-rate | |
|  多播支持 | --ttl | --ttl | | -m |
|  双向测试 | --dualtest | --dualtest | | |
| 转发和CWND报告 | | -e | 默认开启 | -br/-bc  |
| 跳过TCP慢启动 | | | --omit | |
| 设置TCP拥塞控制alg | -Z | -Z | --congestion | |
| 零拷贝(sendfile) | | | --zerocopy | |
| UDP burst模式 | | | | -Ri#/# |
| MS Windows支持 | 是 | 是 | 没有 | 没有 |
## 用途建议如下
* 将iperf2用于并行流双向或基于MS Windows的测试
* 使用nuttcp进行高速UDP测试
* 否则使用iperf3。特别是如果你想要详细的JSON输出
## iperf3常见问题
```markdown
iperf3是单线程的而iperf2是多线程的。建议将iperf2用于并行流将iperf3用于并行流参考
https://fasterdata.es.net/performance-testing/network-troubleshooting-tools/iperf/multi-stream-iperf3/
UDP速率低于100Kbps时需要减少默认数据包长度使用-l100选项
使用-fq-rate选项时需要内核配置修改net.core.default_qdisc = fq
```
```markdown
客户端与服务器共用选项
-f, --format [bkmaBKMA] 格式化带宽数输出。支持的格式有: 'b' = bits/sec 'B' = Bytes/sec 'k' = Kbits/sec 'K' = KBytes/sec 'm' = Mbits/sec 'M' = MBytes/sec 'g' = Gbits/sec 'G' = GBytes/sec 'a' = adaptive bits/sec 'A' = adaptive Bytes/sec 自适应格式是kilo-和mega-二者之一。除了带宽之外的字段都输出为字节除非指定输出的格式默认的参数是a。 注意在计算字节byte时Kilo = 1024 Mega = 1024^2Giga = 1024^3。通常在网络中Kilo = 1000 Mega = 1000^2 and Giga = 1000^3所以Iperf也按此来计算比特。如果这些困扰了你那么请使用-f b参数然后亲自计算一下。
-i, --interval # 设置每次报告之间的时间间隔,单位为秒。如果设置为非零值,就会按照此时间间隔输出测试报告。默认值为零。
-l, --len #[KM] 设置读写缓冲区的长度。TCP方式默认为8KBUDP方式默认为1470字节。
-m, --print_mss 输出TCP MSS值通过TCP_MAXSEG支持。MSS值一般比MTU值小40字节。通常情况
-p, --port # 设置端口与服务器端的监听端口一致。默认是5001端口与ttcp的一样。
-u, --udp 使用UDP方式而不是TCP方式。参看-b选项。
-w, --window #[KM] 设置套接字缓冲区为指定大小。对于TCP方式此设置为TCP窗口大小。对于UDP方式此设置为接受UDP数据包的缓冲区大小限制可以接受数据包的最大值。
-B, --bind host 绑定到主机的多个地址中的一个。对于客户端来说这个参数设置了出栈接口。对于服务器端来说这个参数设置入栈接口。这个参数只用于具有多网络接口的主机。在Iperf的UDP模式下此参数用于绑定和加入一个多播组。使用范围在224.0.0.0至239.255.255.255的多播地址。参考-T参数。
-C, --compatibility 与低版本的Iperf使用时可以使用兼容模式。不需要两端同时使用兼容模式但是强烈推荐两端同时使用兼容模式。某些情况下使用某些数据流可以引起1.7版本的服务器端崩溃或引起非预期的连接尝试。
-M, --mss #ip头减去40字节。在以太网中MSS值 为1460字节MTU1500字节。许多操作系统不支持此选项。
-N, --nodelay 设置TCP无延迟选项禁用Nagle's运算法则。通常情况此选项对于交互程序例如telnet是禁用的。
-V (from v1.6 or higher) 绑定一个IPv6地址。 服务端:$ iperf -s V 客户端:$ iperf -c -V 注意在1.6.3或更高版本中指定IPv6地址不需要使用-B参数绑定在1.6之前的版本则需要。在大多数操作系统中将响应IPv4客户端映射的IPv4地址。
服务器端专用选项
-s, --server Iperf服务器模式
-D (v1.2或更高版本) Unix平台下Iperf作为后台守护进程运行。在Win32平台下Iperf将作为服务运行。
-R(v1.2或更高版本仅用于Windows) 卸载Iperf服务如果它在运行
-o(v1.2或更高版本仅用于Windows) 重定向输出到指定文件
-c, --client host 如果Iperf运行在服务器模式并且用-c参数指定一个主机那么Iperf将只接受指定主机的连接。此参数不能工作于UDP模式。
-P, --parallel # 服务器关闭之前保持的连接数。默认是0这意味着永远接受连接。
客户端专用选项
-b, --bandwidth #[KM] UDP模式使用的带宽单位bits/sec。此选项与-u选项相关。默认值是1 Mbit/sec。
-c, --client host 运行Iperf的客户端模式连接到指定的Iperf服务器端。
-d, --dualtest 运行双测试模式。这将使服务器端反向连接到客户端,使用-L 参数中指定的端口(或默认使用客户端连接到服务器端的端口)。这些在操作的同时就立即完成了。如果你想要一个交互的测试,请尝试-r参数。
-n, --num #[KM] 传送的缓冲器数量。通常情况Iperf按照10秒钟发送数据。-n参数跨越此限制按照指定次数发送指定长度的数据而不论该操作耗费多少时间。参考-l与-t选项。
-r, --tradeoff 往复测试模式。当客户端到服务器端的测试结束时,服务器端通过-l选项指定的端口或默认为客户端连接到服务器端的端口反向连接至客户端。当客户端连接终止时反向连接随即开始。如果需要同时进行双向测试请尝试-d参数。
-t, --time # 设置传输的总时间。Iperf在指定的时间内重复的发送指定长度的数据包。默认是10秒钟。参考-l与-n选项。
-L, --listenport # 指定服务端反向连接到客户端时使用的端口。默认使用客户端连接至服务端的端口。
-P, --parallel # 线程数。指定客户端与服务端之间使用的线程数。默认是1线程。需要客户端与服务器端同时使用此参数。
-S, --tos # 出栈数据包的服务类型。许多路由器忽略TOS字段。你可以指定这个值使用以"0x"开始的16进制数或以"0"开始的8进制数或10进制数。 例如16进制'0x10' = 8进制'020' = 十进制'16'。TOS值1349就是 IPTOS_LOWDELAY minimize delay 0x10 IPTOS_THROUGHPUT maximize throughput 0x08 IPTOS_RELIABILITY maximize reliability 0x04 IPTOS_LOWCOST minimize cost 0x02
-T, --ttl # 出栈多播数据包的TTL值。这本质上就是数据通过路由器的跳数。默认是1链接本地。
-F (from v1.2 or higher) 使用特定的数据流测量带宽,例如指定的文件。 $ iperf -c -F
-I (from v1.2 or higher) 与-F一样由标准输入输出文件输入数据。
```
## 实例
```bash
# 通过perfSONAR安装,最好设置tcp拥塞算法为net.ipv4.tcp_congestion_control = htcp
yum install -y http://software.internet2.edu/rpms/el7/x86_64/latest/packages/perfSONAR-repo-0.9-1.noarch.rpm
yum install -y perfsonar-tools # 仅包含运行按需测量所需的命令行客户端owamp twamp nuttcp iperf3 iperf
: << comment
包括perfsonar-tools包中的所有内容以及以下所需的软件
* 定期自动运行测试
* 参与集中管理的测试
* 发布测量节点的存在
comment
yum install -y perfsonar-testpoint
: << comment
perfsonar-core bundle install包括perfsonar-testpoint bundle install中的所有内容以及用于存储结果的esmond测量存档。这对于希望在
本地存储结果但不希望安装perfSONAR Toolkit的专用测量主机来说非常理想。换句话说他们不想使用Web界面并希望灵活地选择默认安全性和调整设置
comment
yum install -y perfsonar-core
: << comment
包含perfsonar-core bundle中的所有内容
用于管理测试的Web界面
脚本用于应用系统范围的默认调整和安全设置
此捆绑包适用于那些希望安装perfSONAR Toolkit ISO中包含的全套工具但在现有Linux系统上的工具包
comment
yum install -y perfsonar-toolkit
: << comment
perfsonar-centralmanagement捆绑包独立于上面的捆绑包并安装集中管理大量主机并显示其结果所需的工具。这包括esmond测量存档用于发布
任务模板的工具和用于显示结果的仪表板软件(MaDDash)
comment
yum install -y perfsonar-centralmanagement
--logfile选项。如何实时查看文件输出使用--forceflush标志。
iperf -u -s # 带宽测试通常采用UDP模式因为能测出极限带宽、时延抖动、丢包率。在进行测试时首先以链路理论带宽作为数据发送速率进行测试
# 例如从客户端到服务器之间的链路的理论带宽为100Mbps先用`-b 100M`进行测试,然后根据测试结果(包括实际带宽,时延抖动和丢包率),再以
# 实际带宽作为数据发送速率进行测试,会发现时延抖动和丢包率比第一次好很多,重复测试几次,就能得出稳定的实际带宽。
**UDP模式**
服务器端:
```
客户端:
```
iperf -u -c 192.168.1.1 -b 100M -t 60
```
在udp模式下以100Mbps为数据发送速率客户端到服务器192.168.1.1上传带宽测试测试时间为60秒。
```
iperf -u -c 192.168.1.1 -b 5M -P 30 -t 60
```
客户端同时向服务器端发起30个连接线程以5Mbps为数据发送速率。
```
iperf -u -c 192.168.1.1 -b 100M -d -t 60
```
以100M为数据发送速率进行上下行带宽测试。
**TCP模式**
服务器端:
```
iperf -s
```
客户端:
```
iperf -c 192.168.1.1 -t 60
```
在tcp模式下客户端到服务器192.168.1.1上传带宽测试测试时间为60秒。
```
iperf -c 192.168.1.1 -P 30 -t 60
```
客户端同时向服务器端发起30个连接线程。
```
iperf -c 192.168.1.1 -d -t 60
```
进行上下行带宽测试。