免费注册 查看新帖 |

Chinaunix

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

一个端口是否只能被一个进程监听? [复制链接]

论坛徽章:
0
11 [报告]
发表于 2008-05-06 22:40 |只看该作者
LINUX下, 多个线程(进程)监听(等待在accept)同一个SOCKET是可以的, 而且根本没有惊群问题.

也就是说, 有连接进来了, OS将选择其中一个进程返回, 其它的不返回.

论坛徽章:
0
12 [报告]
发表于 2008-05-07 08:15 |只看该作者
原帖由 system888net 于 2008-5-6 20:20 发表


是这样的!
若各个服务的进程是相同的,则不会造成混乱, 但若各进程是不同的服务, 对用户而言可能会有些不方便或混乱!


顶班,不管有没有"惊群",  多个提供不同服务的进程在同一端口会使用户混乱!

论坛徽章:
0
13 [报告]
发表于 2008-05-07 09:11 |只看该作者
不要那样用(不同服务).

一般是: 多线程(进程)阻塞accept一个SOCKET, 有返回的, 自己处理. 这样, 免去了accept之后再FORK的代价.
没有惊群问题.


原帖由 hzcgz 于 2008-5-7 08:15 发表


顶班,不管有没有"惊群",  多个提供不同服务的进程在同一端口会使用户混乱!

论坛徽章:
0
14 [报告]
发表于 2008-05-08 10:51 |只看该作者
原帖由 思一克 于 2008-5-7 09:11 发表
不要那样用(不同服务).

一般是: 多线程(进程)阻塞accept一个SOCKET, 有返回的, 自己处理. 这样, 免去了accept之后再FORK的代价.
没有惊群问题.




凡事避其短而用其长,这是解决问题的思维. 顶...

论坛徽章:
0
15 [报告]
发表于 2014-12-10 00:34 |只看该作者
回复 9# flw


    错,惊群是指同时accept同一个fd,且这个fd指向同一个file结构体,直接的说就是父进程绑定port后,fork的子进程同时accept同一个fd,这才是惊群

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
16 [报告]
发表于 2014-12-11 01:11 |只看该作者
多进程监听同一个地址,以前的只有一个办法:一个进程监听,然后这个进程fork出多个进程,这样这些进程就同时监听这一个地址了。
现在新版内核有了REUSE_PORT的选项(不是REUSE_ADDR),可以让多个独立的进程监听同一个地址了,你可以百度下,REDHAT7已经可以用这个选项了。

论坛徽章:
0
17 [报告]
发表于 2014-12-11 19:08 |只看该作者
给aacpet加锁
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP