Netperf是一种网络性能的测量工具,主要针对基于TCP或UDP的传输。Netperf根据应用的不同,可以进行不同模式的网络性能测试,即批量数据传输(bulk data transfer)模式和请求/应答(request/reponse)模式。

工作原理

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

软件安装

  1. 下载安装Netperf工具
  下载链接:ftp://ftp.netperf.org/netperf/
  [root@xiesshavip001 ~]# wget ftp://ftp.netperf.org/netperf/netperf-2.7.0.tar.gz
  1. 安装依赖包gcc cc
  [root@xiesshavip001 ~]# yum install gcc cc -y
  1. 解压安装

    发行版Linux(CentOS7等)下编译和安装步骤如下:

  1.   [root@xiesshavip001 ~]# tar -zxvf netperf-2.7..tar.gz
      [root@xiesshavip001 ~]#cd ./netperf-2.7./
      [root@xiesshavip001 netperf-2.7.]# ./configure
      [root@xiesshavip001 netperf-2.7.]# cd ./src/
      [root@xiesshavip001 netperf-2.7.]# make
      [root@xiesshavip001 netperf-2.7.]# make install

    麒麟操作系统Linux(银河麒麟,搭配的是飞腾1500A 64位处理器)下编译和安装步骤如下:

  [root@xiesshavip001 ~]# tar -zxvf netperf-2.7.0.tar.gz
  [root@xiesshavip001 ~]#cd ./netperf-2.7.0/
  [root@xiesshavip001 netperf-2.7.0]# ./configure  –build=alpha //注释:此处指定编译平台为alpha
  [root@xiesshavip001 netperf-2.7.0]# cd ./src/
  [root@xiesshavip001 netperf-2.7.0]# make
  [root@xiesshavip001 netperf-2.7.0]# make install

命令参数介绍

命令行参数包括如下选项:

-H host :指定远端运行netserver的server IP地址。
-l testlen:指定测试的时间长度(秒)
-t testname:指定进行的测试类型,包括TCP_STREAM,UDP_STREAM,TCP_RR,TCP_CRR,UDP_RR
-s size 设置本地系统的socket发送与接收缓冲大小
-S size 设置远端系统的socket发送与接收缓冲大小
-m size 设置本地系统发送测试分组的大小
-M size 设置远端系统接收测试分组的大小
-D 对本地与远端系统的socket设置TCP_NODELAY选项

netperf 网络测试

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

  1. [root@xiesshavip002 ~]# netserver  # 服务端启动netserver 服务
    Starting netserver with host 'IN(6)ADDR_ANY' port '' and family AF_UNSPEC
    [root@xiesshavip001 ~]# netperf -H 192.168.130.20 -l
    MIGRATED TCP STREAM TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET
    Recv Send Send
    Socket Socket Message Elapsed
    Size Size Size Time Throughput
    bytes bytes bytes secs. ^6bits/sec
    60.01 935.66
    [root@xiesshavip001 ~]#
    [root@xiesshavip001 ~]# netperf -H 192.168.130.20 -l -- -m # 修改发送的包的大小
    MIGRATED TCP STREAM TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET
    Recv Send Send
    Socket Socket Message Elapsed
    Size Size Size Time Throughput
    bytes bytes bytes secs. ^6bits/sec 60.02 937.58

2、UDP_STREAM UDP_STREAM用来测试进行UDP批量传输时的网络性能。注意:此时测试分组的大小不得大于socket的发送与接收缓冲大小,否则netperf会报出错提示:

[root@xiesshavip001 ~]# netperf -t UDP_STREAM  -H 192.168.130.20 -l
MIGRATED UDP STREAM TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET
Socket Message Elapsed Messages
Size Size Time Okay Errors Throughput
bytes bytes secs # # ^6bits/sec 10.01 6874.75
10.01 0.05 [root@xiesshavip001 ~]#
[root@xiesshavip001 ~]# netperf -t UDP_STREAM -H 192.168.130.20 -l -- -m # 超过socket的发送与接收缓冲大212992
MIGRATED UDP STREAM TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET
send_data: data send error: Message too long (errno )
netperf: send_omni: send_data failed: Message too long

3、TCP_RR TCP_RR方式的测试对象是多次TCP request和response的交易过程

  1. [root@xiesshavip001 ~]# netperf -t TCP_RR -H 192.168.130.20
    MIGRATED TCP REQUEST/RESPONSE TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET : first burst
    Local /Remote
    Socket Size Request Resp. Elapsed Trans.
    Send Recv Size Size Time Rate
    bytes Bytes bytes bytes secs. per sec 10.00 8228.63

    我们可以通过测试相关的参数来改变request和response分组的大小,TCP_RR方式下的参数如下表所示:

    参数	           说明
    -r req,resp 设置request和reponse分组的大小
    -s size 设置本地系统的socket发送与接收缓冲大小
    -S size 设置远端系统的socket发送与接收缓冲大小
    -D 对本地与远端系统的socket设置TCP_NODELAY选项
  2. [root@xiesshavip001 ~]# netperf -t TCP_RR -H 192.168.130.20 -- -r
    MIGRATED TCP REQUEST/RESPONSE TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET : first burst
    Local /Remote
    Socket Size Request Resp. Elapsed Trans.
    Send Recv Size Size Time Rate
    bytes Bytes bytes bytes secs. per sec 10.00 8143.22

4、TCP_CRR 与TCP_RR不同,TCP_CRR为每次交易建立一个新的TCP连接。

[root@xiesshavip001 ~]# netperf -t TCP_CRR -H 192.168.130.20
MIGRATED TCP Connect/Request/Response TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET
Local /Remote
Socket Size Request Resp. Elapsed Trans.
Send Recv Size Size Time Rate
bytes Bytes bytes bytes secs. per sec 10.00 899.38 # 数值明显比TCP_RR值小

5、UDP_RR UDP_RR方式使用UDP分组进行request/response的交易过程

[root@xiesshavip001 ~]# netperf -t UDP_RR -H 192.168.130.20
MIGRATED UDP REQUEST/RESPONSE TEST from 0.0.0.0 (0.0.0.0) port AF_INET to 192.168.130.20 () port AF_INET : first burst
Local /Remote
Socket Size Request Resp. Elapsed Trans.
Send Recv Size Size Time Rate
bytes Bytes bytes bytes secs. per sec 10.00 8425.86

6、netperf 的命令使用帮助:netperf --help

[root@xiesshavip001 ~]# netperf --help
netperf: invalid option -- '-' Usage: netperf [global options] -- [test options] Global options:
-a send,recv Set the local send,recv buffer alignment
-A send,recv Set the remote send,recv buffer alignment
-B brandstr Specify a string to be emitted with brief output
-c [cpu_rate] Report local CPU usage
-C [cpu_rate] Report remote CPU usage
-d Increase debugging output
-D time,[units] * Display interim results at least every time interval
using units as the initial guess for units per second
A negative value for time will make heavy use of the
system's timestamping functionality
-f G|M|K|g|m|k Set the output units
-F lfill[,rfill]* Pre-fill buffers with data from specified file
-h Display this text
-H name|ip,fam * Specify the target machine and/or local ip and family
-i max,min Specify the max and min number of iterations (,)
-I lvl[,intvl] Specify confidence level ( or ) ()
and confidence interval in percentage ()
-j Keep additional timing statistics
-l testlen Specify test duration (> secs) (< bytes|trans)
-L name|ip,fam * Specify the local ip|name and address family
-o send,recv Set the local send,recv buffer offsets
-O send,recv Set the remote send,recv buffer offset
-n numcpu Set the number of processors for CPU util
-N Establish no control connection, do 'send' side only
-p port,lport* Specify netserver port number and/or local port
-P | Don't/Do display test headers
-r Allow confidence to be hit on result only
-s seconds Wait seconds between test setup and test start
-S Set SO_KEEPALIVE on the data connection
-t testname Specify test to perform
-T lcpu,rcpu Request netperf/netserver be bound to local/remote cpu
-v verbosity Specify the verbosity level
-W send,recv Set the number of send,recv buffers
-v level Set the verbosity level (default , min )
-V Display the netperf version and exit
-y local,remote Set the socket priority
-Y local,remote Set the IP_TOS. Use hexadecimal.
-Z passphrase Set and pass to netserver a passphrase For those options taking two parms, at least one must be specified;
specifying one value without a comma will set both parms to that
value, specifying a value with a leading comma will set just the second
parm, a value with a trailing comma will set just the first. To set
each parm to unique values, specify both and separate them with a
comma. * For these options taking two parms, specifying one value with no comma
will only set the first parms and will leave the second at the default
value. To set the second value it must be preceded with a comma or be a
comma-separated pair. This is to retain previous netperf behaviour.

参考链接:

1、源代码和帮助文档

2、netperf 网络性能测试

3、netperf的安装及使用

4、ARM64平台编译stream、netperf出错解决办法

5、netperf使用指南

6、netperf 与网络性能测量

发行版Linux和麒麟操作系统下netperf 网络性能测试的更多相关文章

  1. chmod 权限777 是什么意思(Unix和Linux的各种操作系统下)

    在Unix和Linux的各种操作系统下,每个文件(文件夹也被看作是文件)都按读.写.运行设定权限.例如我用ls -l命令列文件表时,得到如下输出:-rw-r--r-- 1 bu users 2254 ...

  2. top(topas),vmstat,iostat在linux和AIX操作系统下显示情况

    top(topas),vmstat,iostat在linux和AIX操作系统下显示情况 分类: Linux基础 2013-08-09 17:26 1093人阅读 评论(0) 收藏 举报 详细列出各命令 ...

  3. Tsung CentOS 操作系统下搭建tsung性能测试环境_Part 2

    CentOS 操作系统下搭建tsung性能测试环境_Part 2 by:授客 QQ:1033553122 --------------------接CentOS 操作系统下搭建tsung性能测试环境_ ...

  4. Tsung CentOS 操作系统下搭建tsung性能测试环境_Part 1

    CentOS 操作系统下搭建tsung性能测试环境_Part 1 by:授客 QQ:1033553122 步骤1.下载软件安装包 CentOS-6.0-x86_64-bin-DVD1.iso jdk- ...

  5. Linux netperf网络性能测试

    Linux netperf网络性能测试 (2013-10-14 16:07:48) 转载▼     网络性能测量的五项指标 1. 可用性(availability) 测试网络性能的第一步是确定网络是否 ...

  6. Netperf网络性能测试工具详解教程

    本文下载链接: [学习笔记]Netperf网络性能测试工具.pdf 一.Netperf工具简介 1.什么是Netperf ? (1)Netperf是由惠普公司开发的一种网络性能测量工具,主要针对基于T ...

  7. 高手从零开始的全定制发行版-Linux from Scratch

    在制作Linux发行版中Linux from Scratch可谓是真正的大师级.Linux from Scratch是在线的社区创建的一本电子书,目的是帮助那些根深蒂固的想方设法提高计算机性能的人(t ...

  8. netperf 网络性能测试

    Netperf是一种网络性能的测量工具,主要针对基于TCP或UDP的传输.Netperf根据应用的不同,可以进行不同模式的网络性能测试,即批量数据传输(bulk data transfer)模式和请求 ...

  9. CentOS和Redhat发行版linux内核版本的对应关系

    由于Redhat和CentOS的发行版本现在众多,所以我们应该知道CentOS和Redhat及linux内核之间版本的对应关系对维护系统还是很有帮助的.对应的列表如下: Redhat 9.0————— ...

随机推荐

  1. Hamming Problem(hdu3199)

    Hamming Problem Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) ...

  2. Hbase学习之概念与原理

    一.hbase与列式存储 hbase最早起源于谷歌的一篇BigTable的论文,它是由java编写的.开源的一个nosql数据库,同时它也是一个列式存储的.支持分布式(基于hdfs)的数据库.什么是列 ...

  3. 说说对npm的开发模式和生产模式的理解

    nodejs这些年的发展非常快,相信没有哪个前端不知道的了,npm也成为了前端开发中经常用到了的一个命令.那么npm不是只用一个 "npm install xxx"命令就够了吗?实 ...

  4. [性能调优]如何通过读PeopleSoft Trace文件来调优

    理解PeopleSoft Trace文件对于解决性能问题是绝对有必要的.你可能面临一个问题,用户抱怨性能较慢,而OEM并没有补货SQL,你有2种方法选择:使用PeopleSoft trace检查或启用 ...

  5. m6c2g核心板使用笔记

    周立功官网资料下载链接:http://www.zlg.cn/ipc/down/down/id/84.html 平台:致远M6G2C-L Cortex-A7工控核心板 主要参考文档:EPC_loT_M6 ...

  6. JavaScript函数节流(throttle)与函数去抖(debounce)

    对于浏览器窗口大小改变的时候,来动态改变页面元素的大小,可以采用window的resize事件,实现代码: <script type="text/javascript"> ...

  7. 防微杜渐——读《C安全编码标准》

    防微杜渐——读<C安全编码标准> 首先这本书的名字是非常洋气的——<C安全编码标准>.然而映入眼帘的却不仅仅是冷冰冰的编码,还有那一套非常严谨的风险评估标准和问题处理方法.对于 ...

  8. 调研getfit

    Gitfit实际是一个提供私人教练的服务,其主要业务有三种,“局部减脂”每天0.5-1小时,对局部高强度的刺激,快速达到塑形目地,不需要复杂器械,0基础也能跟上训练进度,并提供咨询师.营养师团队.专属 ...

  9. python 流程控制(条件语句)

    1,python流程控制单条件基本语句 2,python流程流程多条件控制语句 3,三元运算 1,python流程控制单条件基本语句 if 判断条件: 执行语句…… else: 执行语句…… 判断条件 ...

  10. mysql InnoDB引擎索引超过长度限制

    组合索引长度之和大于 767 bytes并无影响,当有某个字段定义长度大于 767 bytes(1000*3)时,仅产生告警,但不影响创建,超长字段会取前 255 字符作为前缀索引,并且组合索引中字段 ...