免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: linux_c_py_php
打印 上一主题 下一主题

[其他] [基于Epoll内置Leader-Follower服务端实现, 已可达50万echo qps(全新支持Lua啦)] [复制链接]

论坛徽章:
0
141 [报告]
发表于 2013-02-22 13:31 |只看该作者
yulihua49 发表于 2013-02-22 11:31
丢事件了,服务器不响应,有4、5个客户端死等。


一定是你丢包了,不应该是select的问题

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
142 [报告]
发表于 2013-02-22 13:31 |只看该作者
iw1210 发表于 2013-02-22 12:43
回复 133# yulihua49

看代码太累,你说说你的设计吧,每个线程的工作是什么?

一个线程,sched 负责select,并且把响应的事件通过队列提交给workerThread线程(池)。
worker对IO进行处理,最后把需要继续工作的fd重新加入fd_set.
很简单,不难懂啊。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
143 [报告]
发表于 2013-02-22 13:34 |只看该作者
本帖最后由 yulihua49 于 2013-02-22 13:36 编辑
iw1210 发表于 2013-02-22 13:31
一定是你丢包了,不应该是select的问题

没有丢包。worker的工作已经完成,fd_set已经设置,select没有响应。
localhost不可能丢包。也不可能这么多fd一起丢包。

论坛徽章:
0
144 [报告]
发表于 2013-02-22 13:43 |只看该作者
yulihua49 发表于 2013-02-22 10:22
10个连接,每个发10000包,最后有4、5个退不出来。丢事件了。

你弄的啥样?你不是一直坚持用select的吗 ...


每个发10000个包,保证都发出来么?

论坛徽章:
0
145 [报告]
发表于 2013-02-22 14:08 |只看该作者
本帖最后由 iw1210 于 2013-02-22 14:08 编辑

回复 143# yulihua49


    我猜你的包没都发出来,发得太快太多了

论坛徽章:
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
146 [报告]
发表于 2013-02-22 14:52 |只看该作者
@starwing83 的确可以, 可能之前哪里写错了引起的, 搞定了.

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
147 [报告]
发表于 2013-02-22 15:16 |只看该作者
本帖最后由 yulihua49 于 2013-02-22 16:00 编辑

死前的发了。
找到了,select 返回-1;
errno=9,EBADF:
EBADF  An invalid file descriptor was given in one of the sets.  (Perhaps a file  descriptor
              that was already closed, or one on which an error has occurred.)

它这么做我很困难,不知道哪个fd错了。它应该放到exceptFds里作为事件给我才好。
如果已经守候的fd关闭了,是从except_fds里出来的。如刚加入时已经关闭了,直接就-1了。-- 猜的,现在情况是,一部分关闭是从rfds出来的,一部分直接就-1了。
我说iw:你也别用select搞什么服务器了,它根本不适合干这事。

论坛徽章:
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
148 [报告]
发表于 2013-02-22 15:19 |只看该作者
原来昨天测试开了太多客户端了, 实际上嵌入lua程序的性能完全没有下降, 还是近50万的qps...

看样lua不错哦.

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
149 [报告]
发表于 2013-02-25 14:23 |只看该作者
本帖最后由 yulihua49 于 2013-02-25 14:30 编辑
yulihua49 发表于 2013-02-22 15:16
死前的发了。
找到了,select 返回-1;
errno=9,EBADF:


终于把这个史上最屌的服务器搞定。
用select,支持1024个连接,达到70000qps。
我的机器只有2核,线程数为8.你们有大机器的,修改一下帮测测。



select.tar.gz (9.63 KB, 下载次数: 125)

论坛徽章:
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
150 [报告]
发表于 2013-02-25 14:35 |只看该作者
yulihua49 发表于 2013-02-25 14:23
终于把这个史上最屌的服务器搞定。
用select,支持1024个连接,达到70000qps。
我的机器只有2核,线程 ...


我来学习一下。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP