php - 使用swoole的时候出现EPOLLIN handle failed
PHPz
PHPz 2017-04-10 15:42:47
[PHP讨论组]

出现的错误如下

swReactorEpoll_wait#270: EPOLLIN handle failed. fd=17. Error: Success[0].
PHP Warning:  Unknown: swoole_event: onRead handler error in Unknown on line 0

我借鉴了这里面的代码 http://www.oschina.net/news/52997/swoole-1-7-3 ,在处理逻辑时我做了一个简单的轮询分配机制,把主进程获取的任务发送给子进程异步处理

phpfunction process_function(swoole_process $worker) {
    swoole_event_add($worker->pipe, function () use ($worker) {
        $recv = $worker->read();
        // 处理逻辑 ...
    });
}

function dispatch_process($task) {
    global $workers;
    static $pos;

    foreach ($handlers as $handler) {
        $pos = NULL === $pos ? 0 : ($pos < count($workers) - 1 ? $pos + 1 : 0);
        $workers[$pos][1]->write($task);
    }
}

$workers = [];
for ($i = 0; $i < $concurrence; $i ++) {
    $process = new swoole_process('process_function');
    $pid = $process->start();
    $workers[] = [$pid, $process];

    echo "create process {$pid}\n";
}

while (true) {
    $task = $redis->brPop('message', 10);

    if ($task) {
        dispatch_process($task[1]);
    }
}

我刚刚看了下ulimit -a,是默认的1024,所以猜测是不是这里出错,但看报错也不是很像。大家有什么思路吗?


更新,我已经尝试调整过ulimit,没有任何作用。而且这个问题只会在运行一段时间后触发,且内存也没有泄漏。


PHP 5.5.9,swoole 1.7.17

PHPz
PHPz

学习是最好的投资!

全部回复(1)
大家讲道理

你使用的PHP、swoole版本分别是多少?
这个错误表示回调函数执行错误,具体什么原因可能还需要查一下。


此问题的原因是你的PHP代码抛出了异常,未捕获。会导致Swoole的事件回调函数执行失败。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号