想用swoole代替redis实现异步任务队列。
根据官方文档描述,swoole_client的异步非阻塞模式只有cli模式。
那么我们的程序代码怎么利用它去投递异步任务呢?
我的php是在fpm下的,比如一个场景是,用户登录后,我想发个短信给它的邮件地址。想把这个任务交给swoole异步处理,然后登录程序能直接返回登录成功,不要被这个短信请求给阻塞。
首先我知道要开一个server来处理任务。那么投递任务的swoole_client调用这块,从我的登录代码里开始怎么嵌入swoole的执行流程呢?
看到网上有一些所谓的实例讲解,但是都没有明确说具体的调用实现过程... 感到不解
多谢!
1.开一个server来处理任务,绑定Task和Finish事件,server监听某个投递任务的消息
2.php-fpm/apache环境下只能使用同步客户端,向server发送个投递任务消息,server收到后投递任务
3.在server的Task事件中处理任务,任务处理完后触发Finish事件,做一些任务完成后的操作。
可以参考LaravelS对于任务的队列的封装方式:异步的任务队列