Netperf测试技巧

Netperf测试技巧

1.概况

Netperf是一种网络性能的测量工具,主要针对基于TCP或UDP的传输。Netperf根据应用的不同,可以进行不同模式的网络性能测试,即批量数据传输(bulk data transfer)模式和请求/应答(request/reponse)模式。Netperf测试结果所反映的是一个系统能够以多快的速度向另外一个系统发送数据,以及另外一个系统能够以多块的速度接收数据。

Netperf工具以client/server方式工作。server端是netserver,用来侦听来自client端的连接,client端是netperf,用来向server发起网络测试。在client与server之间,首先建立一个控制连接,传递有关测试配置的信息,以及测试的结果;在控制连接建立并传递了测试配置信息以后,client与server之间会再建立一个测试连接,用来来回传递着特殊的流量模式,以测试网络的性能。

2.安装Netperf

(1)运行命令下载Netperf

wget -c "https://codeload.github.com/HewlettPackard/netperf/tar.gz/netperf-2.5.0" -O netperf-2.5.0.tar.gz

(2)运行以下命令安装Netperf

tar -zxvf netperf-2.5.0.tar.gz

cd netperf-netperf-2.5.0

./configure

make

make install

注意:

A:如果在步骤(1)下载失败,直接拷贝地址到浏览器,下载到本地,然后通过命令将本地文件拷贝到服务器。命令如下:

scp 文件名用户名@计算机IP:远程路径

B:如果./configure出错,可能是受权限的问题,将命令修改为:

./configure --prefix=指定目录

C:服务器之间传递文件命令如下:

scp -r [文件路径]@计算机IP:远程路径

(3)验证安装是否成功。运行如下命令:

netperf –h

netserver -h

 

 

 

 

3.Netperf命令行参数

netperf的命令行参数可以分为两大类:全局命令行参数、测试相关的局部参数,两者之间使用--分隔:

netperf [global options]-- [test-specific options]

4.测试网络性能

Netperf 安装完成后,会生成 2 个工具:netserver 和 netperf

主要参数如下:

工具名称

工具说明

主要参数

参数说明

netserver

接收端工具(server 端)

-p

端口号

 

 

 

 

 

 

 

netperf

 

 

 

 

 

 

 

发送端工具(client 端)

 

 

 

-H

指定 ECS 实例的 IP 地址。

-p

指定 ECS 实例的端口。

-l

指定运行时间。

 

-t

TCP_STREAM 或 UDP_STREAM。建议使用 UDP_STREAM。

 

 

-m

指定数据包大小。

  • 测试 PPS 时,该值为 1。

测试 bps(bit per second)时,该值为 1400。

 

4.1测试批量(bulk)网络流量的性能

根据使用传输协议的不同,批量数据传输又分为TCP批量传输和UDP批量传输

(1)TCP_STREAM

Netperf缺省情况下进行TCP批量传输,即-t TCP_STREAM。测试过程中,netperf向netserver发送批量的TCP数据分组,以确定数据传输过程中的吞吐量。

在测试机内启动 netserver

./netserver

陪练机内启动 netperf

./netperf -H 10.87.216.55 -l 60 TCP STREAM TEST to 10.87.216.56

测试结果如下:

Recv   Send    Send

Socket Socket  Message  Elapsed

Size   Size    Size     Time     Throughput

bytes  bytes   bytes    secs.    10^6bits/sec

87380  65536  65536    60.00    9034.56

(2) UDP_STREAM

UDP_STREAM用来测试进行UDP批量传输时的网络性能。需要特别注意的是,此时测试分组的大小不得大于socket的发送与接收缓冲大小。

陪练机启动:

./netperf -t UDP_STREAM -H 10.87.216.55 -l 60 UDP UNIDIRECTIONAL SEND TEST to 10.87.216.56

测试结果如下:

Socket  Message  Elapsed      Messages

Size    Size     Time         Okay Errors   Throughput

bytes   bytes    secs            #      #   10^6bits/sec

212992   65507   60.00     2257105      0    19713.49

16777216           60.00     1549396           13532.38

UDP是不可靠的传输协议,发送出去的分组数量不一定等于接收到的分组数量。

4.2测试请求/应答(request/response)网络流量的性能

另一类常见的网络流量类型是应用在client/server结构中的request/response模式。在每次交易(transaction)中,client向server发出小的查询分组,server接收到请求,经处理后返回大的结果数据。

(1)TCP_RR

TCP_RR方式的测试对象是多次TCP request和response的交易过程,但是它们发生在同一个TCP连接中,这种模式常常出现在数据库应用中。数据库的client程序与server程序建立一个TCP连接以后,就在这个连接中传送数据库的多次交易过程。

./netperf -t TCP_RR -H 10.87.216.55 TCP REQUEST/RESPONSE TEST to 10.87.216.56

测试结果如下:

Socket Size   Request  Resp.   Elapsed  Trans.

Send   Recv   Size     Size    Time     Rate

bytes  Bytes  bytes    bytes   secs.    per sec

65536  87380  1        1       10.01    25258.33

65536  87380

(2)TCP_CRR

与TCP_RR不同,TCP_CRR为每次交易建立一个新的TCP连接。最典型的应用就是HTTP,每次HTTP交易是在一条单独的TCP连接中进行的。因此,由于需要不停地建立新的TCP连接,并且在交易结束后拆除TCP连接,交易率一定会受到很大的影响。

./netperf -t TCP_CRR -H 10.87.216.55 TCP Connect/Request/Response TEST to 10.87.216.56

测试结果如下:

Socket Size   Request  Resp.   Elapsed  Trans.

Send   Recv   Size     Size    Time     Rate

bytes  Bytes  bytes    bytes   secs.    per sec

65536  87380  1        1       10.02    9024.28

65536  87380

(3)UDP_RR

UDP_RR方式使用UDP分组进行request/response的交易过程,由于没有TCP连接所带来的负担,所以交易率一定会有相应的提升。

 

./netperf -t UDP_RR -H 10.87.216.55 UDP REQUEST/RESPONSE TEST to 10.87.216.56

测试结果如下:

Socket Size   Request  Resp.   Elapsed  Trans.

Send   Recv   Size     Size    Time     Rate

bytes  Bytes  bytes    bytes   secs.    per sec

212992 16777216 1        1       10.00    25537.90

212992 16777216

转载于:https://www.cnblogs.com/yinghuali/p/7472230.html

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Linux netperf 是一种常用的网络性能测试工具,用于评估计算机网络的吞吐量、延迟和数据传输效率等指标。它可以通过模拟网络应用程序的客户端和服务器端来进行测试。 在Linux系统中,我们可以使用以下步骤进行 netperf 测试: 1. 安装 netperf:使用包管理器(如apt-get、yum等)安装 netperf 客户端和服务器端软件包。 2. 设置测试环境:根据具体的测试需求,配置测试环境,包括网络拓扑、机器配置等。确保测试客户端和服务器可以正常通信。 3. 启动 netperf 服务器:在服务器上运行 netserver 命令,启动 netperf 服务器。 4. 运行 netperf 客户端:在客户端上运行 netperf 命令,指定服务器的 IP 地址和相关的测试参数。例如,可以使用 netperf -H <服务器IP> -t <测试类型> 来运行测试。 5. 分析测试结果:netperf 测试完成后,会生成测试报告,其中包含吞吐量、延迟、CPU利用率等指标的结果。根据具体需求,可以使用不同的选项和参数进行自定义测试,并对结果进行分析,以便于定位和解决网络性能问题。 总的来说,通过使用 Linux netperf 工具进行网络性能测试,我们可以了解网络的吞吐量和延迟等指标。这对于评估网络设备性能、优化网络配置以及排查网络问题都是非常有帮助的。同时,通过对测试结果的分析,我们还能够进一步优化网络性能,提升系统的稳定性和可靠性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值