swoole如何在php项目中运用,Swoole 在 php框架(Laravel)中是如何实现异步任务队列的...

Swoole 异步任务

实现原理

我们知道,PHP 本身的设计是同步阻塞的,不支持多线程和异步 IO,所以当我们执行一些耗时的操作,比如发送广播,或者邮件,如果直接在当前进程中操作,会导致服务器响应变慢,因此要借助一些第三方服务来处理以实现异步功能,比如队列,而 Swoole 作为 PHP 异步网络通信引擎,自然也对异步任务处理提供了支持,其底层的实现原理和常见的异步队列类似:将耗时任务投递到 TaskWorker 进程池后返回(相应任务会通过 TaskWorker 异步执行,执行成功后可以调用事先注册的回调函数进行后续处理),继续后续业务逻辑的执行,而不影响当前请求的处理速度。关于 TaskWorker 后面我们介绍 Swoole 底层原理的时候还会详细介绍。

示例代码

我们可以基于 Swoole 入门教程中编写的 TCP 服务器为基础来实现一个异步任务服务器用来处理异步任务,只需添加一个任务处理和一个任务完成回调即可,此外,还需要配置 TaskWorker 进程数以保证任务处理的速度,可以根据任务的耗时和任务量配置其值,通常我们可以将其配置为 CPU 数量的两倍:

我们将该文件保存为 async_task_server.php,然后在命令行启动这个服务器:

接下来,启动TCP 客户端:

服务器投递任务到 TaskWorker 后会立即将处理信息发送给客户端:

e86d45092e6c83279d077677ab21dffb.png

然后服务器会异步处理任务:

7b0faf3b1095c6f4159bf6b92fb34243.png

在 Laravel 中基于 Swoole 实现异步任务队列

还是以 LaravelS 扩展包为基础,我们在 Laravel 项目中实现基于 Swoole 实现异步任务队列功能,其原理就是上面介绍的 Swoole 异步任务,只不过该扩展包对其做了封装而已。

编写任务类

首先我们创建一个继承自 Hhxsv5\LaravelS\Swoole\Task\Task基类的待处理任务类 TestTask:

编写测试代码

然后在 routes/web.php编写投递异步任务的测试代码如下:

修改配置文件

此外还要在配置文件 config/laravels.php中取消 task_worker_num 配置项前面的注释:

测试异步任务执行

接下来,我们重启启动 Swoole 服务器(基于 Swoole HTTP 服务器访问路由才能成功投递异步任务):

然后在浏览器中通过 http://todo-s.test/task/test访问测试路由,页面立即显示投递成功:

然后我们去 storage/logs目录下查看最新的日志信息,可以看到任务执行其实耗费了 3 秒:

这样,我们就成功在 Laravel 项目中基于 Swoole 实现了异步任务消费队列.

67e3f3660c2aa6143a7b2c3d35c044c7.png

举报/反馈

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值