qperf测量网络带宽和延迟
我们在做网络服务器的时候,通常会很关心网络的带宽和延迟。因为我们的很多协议都是request-reponse协议,延迟决定了最大的QPS,而带宽决定了最大的负荷。 通常我们知道自己的网卡是什么型号,交换机什么型号,主机之间的物理距离是多少,理论上是知道带宽和延迟是多少的。但是现实的情况是,真正的带宽和延迟情况会有很多变数的,比如说网卡驱动,交换机跳数,丢包率,协议栈配置,光实际速度都很大的影响了数值的估算。 所以我们需要找到工具来实际测量下。
网络测量的工具有很多,netperf什么的都很不错。 我这里推荐了qperf,这是RHEL 6发行版里面自带的,所以使用起来很方便,只要简单的:
1 |
yum install qperf |
就好。
使用起来也相当简单:
在其中一台机器上运行qperf,不带任何参数就好,这台机器就充当服务器角色:
1 2 3 |
$ uname -r 2.6.32-131.21.1.tb477.el6.x86_64 $ qperf |
在另外一台机器上运行qperf,测量tcp的带宽和延时,顺便看下双方机器的配置情况:
1 2 3 4 5 6 7 8 9 10 11 12 13 |
$ qperf 10.232.64.yyy tcp_bw tcp_lat conf tcp_bw: bw = 118 MB/sec tcp_lat: latency = 31.9 us conf: loc_node = xxx.sqa.cm4 loc_cpu = 16 Cores: Intel Xeon L5630 @ 2.13GHz loc_os = Linux 2.6.32-131.21.1.tb477.el6.x86_64 loc_qperf = 0.4.6 rem_node = yyy.sqa.cm4 rem_cpu = 16 Cores: Intel Xeon L5630 @ 2.13GHz rem_os = Linux 2.6.32-131.21.1.tb477.el6.x86_64 |
是不是很方便?典型情况下我们的带宽是118M,延迟是32us, 在标准的千M环境下是符合预期的。
当然qperf有很多高级参数,可以设置socket buffer的大小,绑定CPU亲缘性等, 很赞的一个特性是可以通过持续改变某个重要参数的值,来观察临界点.
比如我们可以透过改变消息的大小(msg_size),比如从1个字节到64K,每次倍增的方式,来观察带宽和延迟的变化情况,演示下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 |
$ qperf -oo msg_size:1:64K:*2 10.232.64.yyy tcp_bw tcp_lat tcp_bw: bw = 2.43 MB/sec tcp_bw: bw = 4.69 MB/sec tcp_bw: bw = 9.12 MB/sec tcp_bw: bw = 18.5 MB/sec tcp_bw: bw = 33.1 MB/sec tcp_bw: bw = 61.4 MB/sec tcp_bw: bw = 114 MB/sec tcp_bw: bw = 118 MB/sec tcp_bw: bw = 113 MB/sec tcp_bw: bw = 114 MB/sec tcp_bw: bw = 114 MB/sec tcp_bw: bw = 118 MB/sec tcp_bw: bw = 117 MB/sec tcp_bw: bw = 118 MB/sec tcp_bw: bw = 118 MB/sec tcp_bw: bw = 117 MB/sec tcp_bw: bw = 117 MB/sec tcp_lat: latency = 31 us tcp_lat: latency = 31.1 us tcp_lat: latency = 31.1 us tcp_lat: latency = 31.4 us tcp_lat: latency = 30.8 us tcp_lat: latency = 32.1 us tcp_lat: latency = 32.6 us tcp_lat: latency = 33.3 us tcp_lat: latency = 35.5 us tcp_lat: latency = 38.6 us tcp_lat: latency = 50.1 us tcp_lat: latency = 69.6 us tcp_lat: latency = 88 us tcp_lat: latency = 128 us tcp_lat: latency = 209 us tcp_lat: latency = 365 us tcp_lat: latency = 650 us |
我们可以看到当包的大小达到64字节的时候,带宽就上不去了;包到达1K的时候,延迟有了很大的变化。 这些临界点对我们的服务器编程时候对性能的估计和预期非常有帮助。
qperf除了测量tcp的,还可以测试rdma, udp, sctp等主流网络协议的带宽和延迟,算是个很新的工具,推荐大家使用。
引自:http://blog.yufeng.info/archives/2234
建议继续学习:
- 两个精彩的比喻:吞吐量和延迟、信号量和互斥锁 (阅读:6139)
- 系统架构的一些思考 (阅读:5759)
- 限制单个进程的带宽 (阅读:3688)
- 时延和带宽的关系 (阅读:3528)
- 一些队列理论 吞吐量、延迟和带宽 (阅读:3287)
- latencytop深度了解你的Linux系统的延迟 (阅读:3254)
- 网络方面一些经验 (阅读:3260)
- Velocity:TCP与低带宽网络的性能【译】 (阅读:3277)
- 延迟加载图片的jQuery插件-Lazy Load Plugin for JQuery (阅读:2855)
- linux时间相关结构体和函数整理 (阅读:2526)
扫一扫订阅我的微信号:IT技术博客大学习
- 作者:Elton 来源: Elton's Blog
- 标签: qperf 带宽 延迟
- 发布时间:2012-10-22 23:32:23
- [47] WEB系统需要关注的一些点
- [47] Oracle MTS模式下 进程地址与会话信
- [45] android 开发入门
- [45] 【社会化设计】自我(self)部分――欢迎区
- [45] Go Reflect 性能
- [45] IOS安全–浅谈关于IOS加固的几种方法
- [44] Twitter/微博客的学习摘要
- [42] find命令的一点注意事项
- [42] 图书馆的世界纪录
- [41] 关于恐惧的自白