使用swoole的时候出现EPOLLIN handle failed

出现的错误如下

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

阅读 4.5k
1 个回答

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


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

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题