swoole-co-pool 介绍
介绍
Swoole 协程工作池,它可以限定你的同时工作协程数量,并且减少协程频繁创建销毁的损耗。
原理
事先定好协程数量和工作队列长度,将所有工作协程事先创建好。
使用 Swoole\Coroutine\Channel 实现工作队列。
在每个工作协程中,Swoole\Coroutine\Channel->pop()。一旦有新的任务 push 进队列,就会有一个工作协程被唤醒。
安装
在您的composer.json中加入配置:
{ "require": { "yurunsoft/swoole-co-pool": "~1.0" } }
然后执行composer update命令。
使用
use Yurun\Swoole\copool\copool; use Yurun\Swoole\copool\Interfaces\ICoTask; use Yurun\Swoole\copool\Interfaces\ITaskParam; $coCount = 10; // 同时工作协程数 $queueLength = 1024; // 队列长度 $pool = new copool($coCount, $queueLength, // 定义任务匿名类,当然你也可以定义成普通类,传入完整类名 new class implements ICoTask { /** * 执行任务 * * @param ITaskParam $param * @return mixed */ public function run(ITaskParam $param) { // 执行任务 return true; // 返回任务执行结果,非必须 } } ); $data = 1; // 可以传递任何参数 // 增加任务,并挂起协程等待返回任务执行结果 $result = $pool->addTask($data); // 增加任务,异步回调 $result = $pool->addTask($data, function(ITaskParam $param, $data){ // 异步回调 });
代码示例
详见 test/test.PHP
swoole-co-pool 官网
https://gitee.com/yurunsoft/swoole-co-pool
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。