免费注册 查看新帖 |

Chinaunix

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

perl fork 和 AnyEvent, AnyEvent::Ping [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-07 21:51 |只看该作者 |倒序浏览

  我有200个ip,然后在fork以后,父进程接受前100个ip,然后子进程接受后100个ip 。然后对任一进程我都使用AnyEvent+AnyEvent:ing去Ping这100个ip,结果运行时,各种报错啊。。


难道AnyEvent:ing+AnyEvent不能用于多进程fork或者多线程中threads ?

论坛徽章:
1
2015年辞旧岁徽章
日期:2015-03-03 16:54:15
2 [报告]
发表于 2013-01-09 07:46 |只看该作者
设计错误。
应该用单进程单线程非阻塞实现。

论坛徽章:
0
3 [报告]
发表于 2013-01-09 14:26 |只看该作者
这个可以用
Parallel::ForkManager

把任务平分到多核上,在用coro+anyevent


论坛徽章:
0
4 [报告]
发表于 2013-01-09 15:46 |只看该作者
bio_tt 发表于 2013-01-07 21:51
我有200个ip,然后在fork以后,父进程接受前100个ip,然后子进程接受后100个ip 。然后对任一进程我都使用 ...


AnyEvent可以跟多进程结合用。或者用POE框架,里面集成fork和AnyEvent。

论坛徽章:
42
19周年集字徽章-周
日期:2019-10-14 14:35:31平安夜徽章
日期:2015-12-26 00:06:30数据库技术版块每日发帖之星
日期:2015-12-01 06:20:002015亚冠之首尔
日期:2015-11-04 22:25:43IT运维版块每日发帖之星
日期:2015-08-17 06:20:00寅虎
日期:2014-06-04 16:25:27狮子座
日期:2014-05-12 11:00:00辰龙
日期:2013-12-20 17:07:19射手座
日期:2013-10-24 21:01:23CU十二周年纪念徽章
日期:2013-10-24 15:41:34IT运维版块每日发帖之星
日期:2016-01-27 06:20:0015-16赛季CBA联赛之新疆
日期:2016-06-07 14:10:01
5 [报告]
发表于 2013-01-09 15:51 |只看该作者
本帖最后由 laputa73 于 2013-01-09 15:54 编辑

ping这种应用场合,完全没必要多进程.因为icmp是可以发了不管的.
所以能力完全取决于网卡的处理能力
我的例子只是为了方面说明限制了100的并发
实际上,一次发1000个完全没有问题
用coro+anyevent::ping是很合适的
而且,就算一次限制100并发.
协程也可以在做完一个ip后ping剩下的ip
我的例子里面就是ping 253个ip的
就是一个简单队列
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP