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核,线程 ...

我来学习一下。
页: 5 6 7 8 9 10 11 12 13 14 [15] 16 17 18 19 20 21 22 23 24
查看完整版本: [基于Epoll内置Leader-Follower服务端实现, 已可达50万echo qps(全新支持Lua啦)]