免费注册 查看新帖 |

Chinaunix

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

[C++] 【开源】C++异步网络框架,希望对感兴趣的同学带来一些启发。 [复制链接]

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-10-23 16:37 |只看该作者 |倒序浏览
发布一个源创的linux C++异步网络框架, 基于工作需求,偏重工程实践。

开发者不需关心 连接,监听,以及底层I/O,只需关注业务自身,这是网络框架的目标。

内置的唤醒接口可以轻松将框架扩展至多线程工作模式:https://code.csdn.net/qq120848369/ez_poll

对于这类工作中常用的库,比如网络库,日志库,配置库,我不喜欢用开源代码,我更喜欢自己实现一份,根据需求慢慢的优化和扩展,作为随身携带的战斗武器,走到哪里都能掏出来用。

网络库我也发过几个,但对代码的设计实现一直不是很满意,主要源于接口的一致性不高,工程实践性不强。 所以,我也思考了很多设计方法,现在这份代码我感觉至少能够让我满意。

项目内有sample可以参考,例子的设计风格参考了我们部门常见的C++设计风格,实践性比较强。

有兴趣同学可以围观一下,暂时sample的测试没有什么内存和功能问题。

后续我会持续维护这个库,用在一些复杂的网络项目里。 没有不含BUG的代码,大家发现问题一定要反馈给我修复,谢谢。

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
2 [报告]
发表于 2013-10-23 17:00 |只看该作者
回复 1# linux_c_py_php


    有性能测试报告吗?简单看了看代码写的挺清晰,编码风格咱们是一样的,呵呵。建议你把assert写到编译条件中去,并把考虑把线程模型整合到框架里去,网络框架不能没有多线程管理啊。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
3 [报告]
发表于 2013-10-23 17:04 |只看该作者
myworkstation 发表于 2013-10-23 17:00
回复 1# linux_c_py_php


性能我用callgrind/kcachegrind剖析过了, 没有明显实现上的瓶颈, QPS没有单测过, 我稍后简单测一下贴个数据, 估计就是个正常水平, 很难差太多也很难好太多.


多线程这两天抽空做进框架好了, 我也感觉有点麻烦.

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
4 [报告]
发表于 2013-10-23 17:23 |只看该作者
本帖最后由 linux_c_py_php 于 2013-10-23 17:26 编辑
top - 17:22:59 up 268 days,  2:29,  2 users,  load average: 6.39, 6.83, 7.16
Tasks: 439 total,   8 running, 422 sleeping,   9 stopped,   0 zombie
Cpu(s): 15.2% us, 35.2% sy,  0.1% ni,  2.2% id,  0.0% wa,  0.0% hi, 47.4% si
Mem:  65878264k total, 32571748k used, 33306516k free,   627076k buffers
Swap:  1020088k total,   138440k used,   881648k free, 24328920k cached

  PID USER      PR  NI  VIRT  RES  SHR S %CPU %MEM    TIME+  COMMAND                                                                                                
13044 liangdon  16   0  188m  58m  836 S  593  0.1   4:35.69 sample_multi                                                                                            
15629 liangdon  16   0  9692 1152  808 R   96  0.0   0:10.47 sample_client                                                                                          
15619 liangdon  16   0  9692 1152  808 R   96  0.0   0:11.39 sample_client                                                                                          
15777 liangdon  16   0  9692 1152  808 R   95  0.0   0:05.32 sample_client                                                                                          
15620 liangdon  16   0  9692 1152  808 R   94  0.0   0:10.80 sample_client                                                                                          
15605 liangdon  16   0  9692 1152  808 R   93  0.0   0:12.78 sample_client   

1服务端, 5客户端, 40万+的qps, 机器12核心, 服务端8线程, 客户端1线程.



客户端5个核心让出来, 理论上算一下: (40/7) * 12 = 60万, 和我以前搞性能测试时候差不多, 12核机器就是个50万+的qps。

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
5 [报告]
发表于 2013-10-23 18:06 |只看该作者
多谢分享。 楼主代码写的很精简,最喜欢这种风格的代码了

论坛徽章:
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 [报告]
发表于 2013-10-23 18:09 |只看该作者
大蛇好,大蛇棒

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
7 [报告]
发表于 2013-10-24 12:10 |只看该作者
poll(time_out) 你是想空转然后不停的检查 timer哦, 那定时器多了,可不是好事啊,而且采用被动的循环检测缺乏实时性啊。。。尽管可以把timeout时间设的很小,应该像ACE 或libevent一样优雅一些 ))

论坛徽章:
89
水瓶座
日期:2014-04-01 08:53:31天蝎座
日期:2014-04-01 08:53:53天秤座
日期:2014-04-01 08:54:02射手座
日期:2014-04-01 08:54:15子鼠
日期:2014-04-01 08:55:35辰龙
日期:2014-04-01 08:56:36未羊
日期:2014-04-01 08:56:27戌狗
日期:2014-04-01 08:56:13亥猪
日期:2014-04-01 08:56:02亥猪
日期:2014-04-08 08:38:58程序设计版块每日发帖之星
日期:2016-01-05 06:20:00程序设计版块每日发帖之星
日期:2016-01-07 06:20:00
8 [报告]
发表于 2013-10-24 12:19 |只看该作者

论坛徽章:
89
水瓶座
日期:2014-04-01 08:53:31天蝎座
日期:2014-04-01 08:53:53天秤座
日期:2014-04-01 08:54:02射手座
日期:2014-04-01 08:54:15子鼠
日期:2014-04-01 08:55:35辰龙
日期:2014-04-01 08:56:36未羊
日期:2014-04-01 08:56:27戌狗
日期:2014-04-01 08:56:13亥猪
日期:2014-04-01 08:56:02亥猪
日期:2014-04-08 08:38:58程序设计版块每日发帖之星
日期:2016-01-05 06:20:00程序设计版块每日发帖之星
日期:2016-01-07 06:20:00
9 [报告]
发表于 2013-10-24 12:23 |只看该作者
lz,你还是优点货的吗!

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
10 [报告]
发表于 2013-10-24 14:05 |只看该作者
已经将多线程支持合入框架自身, 有兴趣的同学可以继续了解: https://code.csdn.net/qq120848369/ez_poll
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP