iw1210
发表于 2013-02-22 13:31
yulihua49 发表于 2013-02-22 11:31 static/image/common/back.gif
丢事件了,服务器不响应,有4、5个客户端死等。
一定是你丢包了,不应该是select的问题
yulihua49
发表于 2013-02-22 13:31
iw1210 发表于 2013-02-22 12:43 static/image/common/back.gif
回复 133# yulihua49
看代码太累,你说说你的设计吧,每个线程的工作是什么?
一个线程,sched 负责select,并且把响应的事件通过队列提交给workerThread线程(池)。
worker对IO进行处理,最后把需要继续工作的fd重新加入fd_set.
很简单,不难懂啊。
yulihua49
发表于 2013-02-22 13:34
本帖最后由 yulihua49 于 2013-02-22 13:36 编辑
iw1210 发表于 2013-02-22 13:31 static/image/common/back.gif
一定是你丢包了,不应该是select的问题
没有丢包。worker的工作已经完成,fd_set已经设置,select没有响应。
localhost不可能丢包。也不可能这么多fd一起丢包。
iw1210
发表于 2013-02-22 13:43
yulihua49 发表于 2013-02-22 10:22 static/image/common/back.gif
10个连接,每个发10000包,最后有4、5个退不出来。丢事件了。
你弄的啥样?你不是一直坚持用select的吗 ...
每个发10000个包,保证都发出来么?
iw1210
发表于 2013-02-22 14:08
本帖最后由 iw1210 于 2013-02-22 14:08 编辑
回复 143# yulihua49
我猜你的包没都发出来,发得太快太多了
linux_c_py_php
发表于 2013-02-22 14:52
@starwing83 的确可以, 可能之前哪里写错了引起的, 搞定了.
yulihua49
发表于 2013-02-22 15:16
本帖最后由 yulihua49 于 2013-02-22 16:00 编辑
死前的发了。
找到了,select 返回-1;
errno=9,EBADF:
EBADFAn invalid file descriptor was given in one of the sets.(Perhaps a filedescriptor
that was already closed, or one on which an error has occurred.)
它这么做我很困难,不知道哪个fd错了。它应该放到exceptFds里作为事件给我才好。
如果已经守候的fd关闭了,是从except_fds里出来的。如刚加入时已经关闭了,直接就-1了。-- 猜的,现在情况是,一部分关闭是从rfds出来的,一部分直接就-1了。
我说iw:你也别用select搞什么服务器了,它根本不适合干这事。
linux_c_py_php
发表于 2013-02-22 15:19
原来昨天测试开了太多客户端了, 实际上嵌入lua程序的性能完全没有下降, 还是近50万的qps...
看样lua不错哦.
yulihua49
发表于 2013-02-25 14:23
本帖最后由 yulihua49 于 2013-02-25 14:30 编辑
yulihua49 发表于 2013-02-22 15:16 static/image/common/back.gif
死前的发了。
找到了,select 返回-1;
errno=9,EBADF:
终于把这个史上最屌的服务器搞定。
用select,支持1024个连接,达到70000qps。
我的机器只有2核,线程数为8.你们有大机器的,修改一下帮测测。
linux_c_py_php
发表于 2013-02-25 14:35
yulihua49 发表于 2013-02-25 14:23 static/image/common/back.gif
终于把这个史上最屌的服务器搞定。
用select,支持1024个连接,达到70000qps。
我的机器只有2核,线程 ...
我来学习一下。