免费注册 查看新帖 |

Chinaunix

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

epoll_wait() listenfd fork()问题请教 [复制链接]

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-03-13 23:45 |只看该作者 |倒序浏览
本帖最后由 xinglp 于 2010-03-14 11:25 编辑

不知道这样是否正确
1.创建listenfd监听并设置非阻塞
2.fork()一定数量的子进程
3.子进程创建epollfd并注册从父进程继承的listenfd
4.子进程等待在epoll_wait()上

当有链接来的时候所有的子进程都从epoll_wait()上返回了

这样会不会有性能问题

但是这样的情况
1.创建listenfd监听并设置非阻塞
2.fork()一定数量的子进程
3.子进程等待accept()上
当有链接来的时候就只有一个子进程从accept()上返回了,这个应改是正常的现象吧(不唤醒不必要的进程).

请教如何让epoll_wait()在这种情况下能像accept()的行为一样.

谢谢

论坛徽章:
0
2 [报告]
发表于 2010-03-14 09:43 |只看该作者
多线程不可以吗?为什么要是多进程?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
3 [报告]
发表于 2010-03-14 11:24 |只看该作者
epoll_wait()返回 不是一样的么?

论坛徽章:
0
4 [报告]
发表于 2010-03-14 13:37 |只看该作者
不知道这样是否正确
1.创建listenfd监听并设置非阻塞
2.fork()一定数量的子进程
3.子进程创建epollfd并注册从父进程继承的listenfd
4.子进程等待在epoll_wait()上

当有链接来的时候所有的子进程都从epoll_wait()上返回了

这样会不会有性能问题


//这样是有惊群效应,lighthttpd也是这样处理的,accept时你判断一下判断值errno是不是EAGAIN


但是这样的情况
1.创建listenfd监听并设置非阻塞
2.fork()一定数量的子进程
3.子进程等待accept()上
当有链接来的时候就只有一个子进程从accept()上返回了,这个应改是正常的现象吧(不唤醒不必要的进程).

//accept这个最新的内核已经不会有惊群效应了

请教如何让epoll_wait()在这种情况下能像accept()的行为一样.

谢谢

//你可以使用线程池或进程池,也就是主线程或主进程负责accept,有连接来以后分给下面的进程或线程池去处理,各进程或线程epoll_wait他自己的就不会有了。

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
5 [报告]
发表于 2010-03-14 14:36 |只看该作者
本帖最后由 xinglp 于 2010-03-14 14:39 编辑

//这样是有惊群效应,lighthttpd也是这样处理的,accept时你判断一下判断值errno是不是EAGAIN
>>这个已经判断了.

//accept这个最新的内核已经不会有惊群效应了
>>内核2.6.33, 在更新的内核中epoll_wait()会不会也解决这个问题.
//你可以使用线程池或进程池,也就是主线程或主进程负责accept,有连接来以后分给下面的进程或线程池去处理,各进程或线程epoll_wait
>>主进程可一把accept后的套接字传递给子进程么?

论坛徽章:
0
6 [报告]
发表于 2010-03-14 15:13 |只看该作者
//这样是有惊群效应,lighthttpd也是这样处理的,accept时你判断一下判断值errno是不是EAGAIN
>>这个已经判断了.

//accept这个最新的内核已经不会有惊群效应了
>>内核2.6.33, 在更新的内核中epoll_wait()会不会也解决这个问题.

不会,epoll_wait本身就有惊群效应

//你可以使用线程池或进程池,也就是主线程或主进程负责accept,有连接来以后分给下面的进程或线程池去处理,各进程或线程epoll_wait
>>主进程可一把accept后的套接字传递给子进程么?

主进程或主线程accept以后是不是有一个fd socket的专一文件描述符,你判断一下当前进程池或线程池里那一个线程或进程处理的连接数最少,然后你就把这个fd给这个线程或进程处理,以后与这个fd所有的操作都是这个线程或进程去epoll_wait了,这样不就能实行并发处理了吗?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
7 [报告]
发表于 2010-03-14 15:48 |只看该作者
同一个进程的多个线程能传递fd,这个我知道.
但是不同的进程之间怎么传递fd呢?

论坛徽章:
0
8 [报告]
发表于 2010-03-14 20:05 |只看该作者
回复 7# xinglp


    但是不同的进程之间怎么传递fd呢?

    APUE 好像讲过,你看一下APUE中file descriptor passing这一节,好像是讲过的,linux应该是可以传递的。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP