快来测一测你的网速吧!

本教程指导如何使用iPerf进行网络吞吐量测试,iPerf是一种命令行工具,通过测量服务器可以处理的最大网络吞吐量来诊断网络速度问题。它在遇到网络速度问题时特别有用,因为您可以使用iPerf来确定哪个服务器无法达到最大吞吐量。

准备

一台已经设置好可以使用sudo命令的非root账号的CentOS服务器,并且已开启防火墙。没有服务器的同学可以在这里购买,不过我个人更推荐您使用免费的腾讯云开发者实验室进行试验,学会安装后在购买服务器

安装iPerf

iperf软件包包含在大多数Linux发行版的存储库中。

Debian和Ubuntu

apt-get install iperf

CentOS

CentOS存储库没有iPerf。我们使用EPEL存储库,它是用于在RedHat系统(如RHEL和CentOS)上安装第三方软件包的存储库:

yum install epel-release
yum update
yum install iperf

Arch Linux

pacman -S iperf

openSUSE

zypper install iperf

Gentoo

emerge iperf

运行emaint --sync安装iPerf软件包。此外,默认情况下,您需要用iperf命令替换/usr/bin/iperf3。此路径可能因您的iPerf版本而异。

如何使用iPerf

在测试连接的计算机上安装iPerf。如果您在个人计算机上使用基于Unix或Linux的操作系统,则可以在本地计算机上安装iPerf。

但是,如果要测试服务器的吞吐量,最好使用另一台服务器作为终点,因为本地ISP可能会施加可能影响测试结果的网络限制。

TCP客户端和服务器

iPerf需要两个系统,因为一个系统必须充当服务器,而另一个系统充当客户端。客户端连接到您正在测试速度的服务器。

在您计划测试的服务器上,以服务器模式启动iPerf:

iperf -s

您应该看到类似于的输出:

------------------------------------------------------------
Server listening on TCP port 5001
TCP window size: 85.3 KByte (default)
------------------------------------------------------------

在您的第二个服务器上,进行关联操作。替换198.51.100.5为第一个服务器的IP地址。

iperf -c 198.51.100.5
------------------------------------------------------------
Client connecting to 198.51.100.5, TCP port 5001
TCP window size: 45.0 KByte (default)
------------------------------------------------------------
[ 3] local 198.51.100.6 port 50616 connected with 198.51.100.5 port 5001
[ ID] Interval Transfer Bandwidth
[ 3] 0.0-10.1 sec 1.27 GBytes 1.08 Gbits/sec

您还将在iPerf服务器上看到连接和结果:

------------------------------------------------------------
Server listening on TCP port 5001
TCP window size: 85.3 KByte (default)
------------------------------------------------------------
[ 4] local 198.51.100.5 port 5001 connected with 198.51.100.6 port 50616
[ ID] Interval Transfer Bandwidth
[ 4] 0.0-10.1 sec 1.27 GBytes 1.08 Gbits/sec

要停止iPerf服务器进程,请按CTRL + c

UDP客户端和服务器

使用iPerf,您还可以测试通过UDP连接实现的最大吞吐量。

启动UDP iPerf服务器:

iperf -s -u
------------------------------------------------------------
Server listening on UDP port 5001
Receiving 1470 byte datagrams
UDP buffer size: 208 KByte (default)
------------------------------------------------------------

将您的客户端连接到iPerf UDP服务器。替换198.51.100.5为您的IP地址:

iperf -c 198.51.100.5 -u
------------------------------------------------------------
Client connecting to 198.51.100.5, UDP port 5001
Sending 1470 byte datagrams
UDP buffer size: 208 KByte (default)
------------------------------------------------------------
[ 3] local 198.51.100.6 port 58070 connected with 198.51.100.5 port 5001
[ ID] Interval Transfer Bandwidth
[ 3] 0.0-10.0 sec 1.25 MBytes 1.05 Mbits/sec
[ 3] Sent 893 datagrams
[ 3] Server Report:
[ 3] 0.0-10.0 sec 1.25 MBytes 1.05 Mbits/sec 0.084 ms 0/ 893 (0%)

1.05 Mbits / sec远低于TCP测试中观察到的值。它也远远低于1GB 服务器提供的最大出站带宽上限。这是因为默认情况下,iPerf将UDP客户端的带宽限制为每秒1 Mbit。

您可以使用-b标志更改此值,将数字替换为您要测试的最大带宽速率。如果您正在测试网络速度,请将此数字设置为高于服务器提供的最大带宽上限:

iperf -c 198.51.100.5 -u -b 1000m

这告诉客户端尽可能达到每秒1000 Mbits的最大值。该-b标志仅在使用UDP连接时有效,因为iPerf未在TCP客户端上设置带宽限制。

------------------------------------------------------------
Client connecting to 198.51.100.5, UDP port 5001
Sending 1470 byte datagrams
UDP buffer size: 208 KByte (default)
------------------------------------------------------------
[ 3] local 198.51.100.5 port 52308 connected with 198.51.100.5 port 5001
[ ID] Interval Transfer Bandwidth
[ 3] 0.0-10.0 sec 966 MBytes 810 Mbits/sec
[ 3] Sent 688897 datagrams
[ 3] Server Report:
[ 3] 0.0-10.0 sec 966 MBytes 810 Mbits/sec 0.001 ms 0/688896 (0%)
[ 3] 0.0-10.0 sec 1 datagrams received out-of-order

这次的结果数值相当高。

双向测试

在某些情况下,您可能希望测试两台服务器以获得最大吞吐量。使用iPerf提供的内置双向测试功能可以轻松完成此操作。

要测试两个连接,请从客户端运行以下命令:

iperf -c 198.51.100.5 -d

iPerf将在客户端服务器上启动服务器和客户端连接(198.51.100.6)。完成此操作后,iPerf会将iPerf服务器连接到客户端,该连接现在既充当服务器连接又充当客户端连接。

------------------------------------------------------------
Server listening on TCP port 5001
TCP window size: 85.3 KByte (default)
------------------------------------------------------------
------------------------------------------------------------
Client connecting to 198.51.100.5, TCP port 5001
TCP window size: 351 KByte (default)
------------------------------------------------------------
[ 3] local 198.51.100.6 port 50618 connected with 198.51.100.5 port 5001
[ 5] local 198.51.100.6 port 5001 connected with 198.51.100.5 port 58650
[ ID] Interval Transfer Bandwidth
[ 5] 0.0-10.1 sec 1.27 GBytes 1.08 Gbits/sec
[ 3] 0.0-10.2 sec 1.28 GBytes 1.08 Gbits/sec

在服务器上,您将看到:

------------------------------------------------------------
Client connecting to 198.51.100.6, TCP port 5001
TCP window size: 153 KByte (default)
------------------------------------------------------------
[ 6] local 198.51.100.5 port 58650 connected with 198.51.100.6 port 5001
[ 6] 0.0-10.1 sec 1.27 GBytes 1.08 Gbits/sec
[ 5] 0.0-10.2 sec 1.28 GBytes 1.08 Gbits/sec

选项

选项

描述

-f

更改运行测试的格式。例如,您可以使用-f k以每秒Kbits而不是每秒Mbits的速度获得结果。有效选项包括m(Mbits,默认),k(Kbits),K(KBytes)和M(MBytes)。

-V

强制iPerf使用IPv6而不是IPv4。

-u

更改定期带宽测试之间的间隔。例如,-i 60将每60秒生成一个新的带宽报告。默认值为零,其执行一次带宽测试。

-p

更改端口。未指定端口时,默认端口为5001.您必须在客户端和服务器上都使用此标志。

-B

将iPerf绑定到特定的接口或地址。如果通过server命令传递,则将设置传入接口。如果通过client命令传递,则将设置传出接口。

更多信息

有关此主题的其他信息,您可能需要参考以下资源:


参考文献:《Network Throughput Testing with iPerf》

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Linyb极客之路

浅谈高性能数据库集群——读写分离

最近学习了阿里资深技术专家李运华的架构设计关于读写分离的教程,颇有收获,总结一下。

1281
来自专栏Jerry的SAP技术分享

在SAP云平台的CloudFoundry环境下消费ABAP On-Premise OData服务

我的前一篇文章 使用Java+SAP云平台+SAP Cloud Connector调用ABAP On-Premise系统里的函数介绍了在SAP云平台的Neo环境...

1966
来自专栏HappenLee的技术杂谈

LVS-NAT模式的配置详解

由于实验室拟态存储的项目需要通过NAT模式来映射NFS服务器已实现负载均衡的目的,通过调研了多种负载均衡机制,笔者最终选择了LVS的NAT模式来实现需求,接下来...

1273
来自专栏同步博客

CSRF攻击与防御

  CSRF的全名为Cross-site request forgery,它的中文名为 跨站请求伪造(伪造跨站请求【这样读顺口一点】)

1933
来自专栏啸天"s blog

安卓百度网盘Aria2下载脚本

2392
来自专栏腾讯NEXT学位

前端需要了解的 SSO 与 CAS 知识

56014
来自专栏同步博客

会话劫持

  在现实生活中,比如你去市场买菜,在交完钱后你要求先去干一些别的事情,稍候再来拿菜;如果这个时候某个陌生人要求把菜拿走,卖菜的人会把菜给陌生人吗?!当然,这只...

1153
来自专栏杨建荣的学习笔记

​ssh免密码登录设置及问题总结

前几天写了一篇文章关于ssh命令的几个使用小技巧(r11笔记第27天),很多朋友给了不少的建议,其中郭亮同学整理了一篇文章发给我在此表示感谢。 关于ssh免密码...

42110
来自专栏Python中文社区

记一次惊心的网站TCP队列问题排查经历

作者:刘晓明,互联网公司运维技术负责人,拥有10年的互联网开发和运维经验。一直致力于运维工具的开发和运维专家服务的推进,赋能开发,提高效能。

1624
来自专栏吾爱乐享

php学习之走进web开发

1323

扫码关注云+社区

领取腾讯云代金券