免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2616 | 回复: 7
打印 上一主题 下一主题

[C++] 请教, 如何测试服务器的吞吐能力 [复制链接]

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-12-23 06:20:00每日论坛发贴之星
日期:2015-12-23 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-09-21 10:11 |只看该作者 |倒序浏览
我需要测试自己写的服务器程序的吞吐能力:
每秒能够成功接收客户端连接(3次握手)的极限值

我的想法是:
1. 测试服务器的吞吐能力不能掺杂网络因素, 比如因为网速限制导致服务器每秒监听到的网络事件数量受限, 所以测试的时候服务器和客户端应该在同一台机器上进行;
2. 写一个客户端程序, fork出多进程或多线程, 每一个子进程或线程向服务器发起n个连接
3. 服务器设置一个计时器, 每秒打印接受到的连接数量

实际中我尝试(10个, 20个, 50个, 100个)线程, 每个线程向服务器发起1000个连接, 调用的connect函数为阻塞式的(非阻塞的connect也试过, 不知为何很多连接都失败了), 结果: 服务器最高可以每秒成功接受差不多15000个连接
我看网上经常出现的高并发服务器声称每秒能接受几十万个连接, 因此我有些疑惑, 到底是服务器程序有问题, 还是客户端的测试方式有问题, 或者两者都有问题?
最后, 请教一下大家通常是如何测试服务器的并发能力的?

我的服务器程序很简单, 单线程, 一个while循环, 不断调用accept接受连接, 每次成功accept一个连接, 每秒接受的连接计数加一.
  1. while true:
  2.      int conn_fd = accept(listen_fd)
  3.      n_connection ++
复制代码

论坛徽章:
12
2015年辞旧岁徽章
日期:2015-03-03 16:54:1515-16赛季CBA联赛之同曦
日期:2017-03-17 19:13:162016科比退役纪念章
日期:2016-11-07 08:28:12luobin
日期:2016-06-17 17:46:36wusuopu
日期:2016-06-17 17:43:4515-16赛季CBA联赛之福建
日期:2016-01-14 12:49:22程序设计版块每日发帖之星
日期:2015-12-13 06:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:00程序设计版块每日发帖之星
日期:2015-06-08 22:20:002015年亚洲杯之科威特
日期:2015-03-24 14:21:272015年迎新春徽章
日期:2015-03-04 09:57:092016科比退役纪念章
日期:2018-04-10 16:20:18
2 [报告]
发表于 2015-09-21 10:18 |只看该作者
其实跟服务器硬件也有关系

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
3 [报告]
发表于 2015-09-21 10:38 |只看该作者
本机测试意义不大。
高并发服务器一般是说能同时维持几十万、上百万个活动连接吧

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-12-23 06:20:00每日论坛发贴之星
日期:2015-12-23 06:20:00
4 [报告]
发表于 2015-09-21 10:54 |只看该作者
本帖最后由 alwaysR9 于 2015-09-21 10:56 编辑

回复 2# VIP_fuck

github上一个项目,声称可以每秒处理25w的请求, 我试试看

[不能发url, 真是不方便.................................... ]


   

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:49:032015年亚洲杯之中国
日期:2015-04-22 15:52:45
5 [报告]
发表于 2015-09-21 10:55 |只看该作者
我看网上经常出现的高并发服务器声称每秒能接受几十万个连接


别鸟他们, 一般短连接服务能力远远不到这个量, 他们指的是同时在线能力, 长连接的.
根据长连接服务方式不同, 比如简单地推送, 三百万也不是问题.

我这边经验值, 短连接服务能力能破万就是很强悍的, 而且还算是业务逻辑很简单的.

你的因为只是简单的accept, 所以才能一万多.

如果遇到瓶颈, ....懒得写了.....

论坛徽章:
36
子鼠
日期:2013-08-28 22:23:29黄金圣斗士
日期:2015-12-01 11:37:51程序设计版块每日发帖之星
日期:2015-12-14 06:20:00CU十四周年纪念徽章
日期:2015-12-22 16:50:40IT运维版块每日发帖之星
日期:2016-01-25 06:20:0015-16赛季CBA联赛之深圳
日期:2016-01-27 10:31:172016猴年福章徽章
日期:2016-02-18 15:30:3415-16赛季CBA联赛之福建
日期:2016-04-07 11:25:2215-16赛季CBA联赛之青岛
日期:2016-04-29 18:02:5915-16赛季CBA联赛之北控
日期:2016-06-20 17:38:50技术图书徽章
日期:2016-07-19 13:54:03程序设计版块每日发帖之星
日期:2016-08-21 06:20:00
6 [报告]
发表于 2015-09-21 11:22 |只看该作者
25w/s,你得按他们测试所用的同等硬件资源才行

论坛徽章:
208
巨蟹座
日期:2013-09-02 09:16:36卯兔
日期:2013-09-02 20:53:59酉鸡
日期:2013-09-05 21:21:45戌狗
日期:2013-10-15 20:51:17寅虎
日期:2013-10-18 21:13:16白羊座
日期:2013-10-23 21:15:19午马
日期:2013-10-25 21:22:48技术图书徽章
日期:2013-11-01 09:11:32双鱼座
日期:2013-11-01 20:29:44丑牛
日期:2013-11-01 20:40:00卯兔
日期:2013-11-11 09:21:32酉鸡
日期:2013-12-04 19:56:39
7 [报告]
发表于 2015-09-22 09:36 |只看该作者
hellioncu 发表于 2015-09-21 10:38
本机测试意义不大。
高并发服务器一般是说能同时维持几十万、上百万个活动连接吧

关键要看测试的方式,有些鸟写的,自称几十w来的,哥拿过代码一看,mb,你那叫同时在线么,开n的线程,都依次退出了,串行无极限啊

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
8 [报告]
发表于 2015-09-22 10:31 |只看该作者
流氓无产者 发表于 2015-09-22 09:36
关键要看测试的方式,有些鸟写的,自称几十w来的,哥拿过代码一看,mb,你那叫同时在线么,开n的线程,都依 ...


你这么牛,老板给你多少年薪啊
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP