1. 队列优势

任务执行流畅,无需等待。如团长批量发送提货通知(比如500条,正常操作发送完需要等待2分钟)。如开启了队列后,团长点击一下发送,后台队列服务就开始一条条发送,无需团长在操作页面等待发送完成。

可减轻秒杀环节高并发对服务器的压力。

可执行一些定时的任务。

2. 队列功能

①团员收货消息群发 ②自动关闭订单 ③自动收货 ④自动上下架 ⑤秒杀分流 ⑥拼团自动退款和关闭订单 等后续增加的新功能。

3. 基础条件

1. swoole扩展正常安装

社区团购plus系统打开正常,并且未提示swoole_loader未安装

2. 宝塔环境需要删除几个禁用函数、非宝塔的可以在php.ini中删除“disable_functions”中对应的函数

如果您为宝塔环境,请在“软件管理”—>“PHP -7.2”设置页—禁用函数中,删除如下图的5个函数,否则无法开启队列。

队列开启教程二 - 图1

队列开启教程二 - 图2

切记,每次在宝塔更新PHP的时候、或者更新宝塔版本的时候,会自动增加禁用函数,需要再次排查删除,否则队列将无法正常运行!

4. 队列开启及开机自动运行方法

命令解析(根据色块,分割成4句话)

nohup /www/server/php/72/bin/php /www/wwwroot/xxxxx/yii queue/listen >> /www/wwwroot/xxxxx/log/sqtg-log.log 2>&1 &

如果您是宝塔,请按照上面的代码执行

如果非宝塔,请把蓝色内容,改成你服务器实际php7.2文件所在的路径

nohup 和 本行最后一个 & 是指后台运行,/www/xxxx.log 2>&1 是指把错误输出到某个log文件中

php 是指在linux启动php。提示,在“amh”环境下,直接运行php 可能提示报错,参考最下面“php明了无法执行或版本不一致怎么办”,查看操作步骤

/www/wwwroot/xxxxx/yii 是系统根目录中的yii文件 xxxxx 需要改成你的站点根目录

微擎版本的yii文件路径为 /www/wwwroot/xxxxx/addons/worldidc_sqtg/power/yii

queue/listen 是我们的队列监听命令

nohup php /www/wwwroot/xxxxx/yii queue/listen >> /www/wwwroot/xxxxx/log/sqtg-log.log 2>&1 &

所以根据上面的代码,执行代码转化为汉语为“在后台 用php 执行某个目录下的yii文件 然后启用队列监听服务 输出错误到某个log文件 ”

这就是我们队列开启的核心语句。

如图,执行完之后,会提示一条数字

队列开启教程二 - 图3

我们需要确认,队列是否在后台正常运行,输入进程查询命令 ps -aux|grep yii

队列开启教程二 - 图4

队列开启教程二 - 图5

如果查询结果如上图,则队列没有正在在后台运行,请最下方“队列开启命令执行后无后台进程”查看调试方法。

队列开启教程二 - 图6

↑↑↑ 如果查询结果如上图,可看到此次查询到了 yii文件在后台运行的 queue/listen 命令,证明您的队列已经正常开启!

仅此还不行,我们需要把队列设置为开机自动启动。

先执行此命令,开启自动启动功能 chmod +x /etc/rc.d/rc.local

队列开启教程二 - 图7

然后编辑启动脚本 vi /etc/rc.local ,把队列开启命令放入启动脚本

队列开启教程二 - 图8

队列开启教程二 - 图9

然后重启服务器,使用 ps -aux|grep yii 查询队列是否开启,如正常开启,则证明开启启动已生效。

5. 常见问题及解决方法

一、 php命令无法执行或版本不一致怎么办?

在某些集成环境下,php命令没有设置,无法自动运行,如下图。

队列开启教程二 - 图10

此图 执行 php -v 下面提示 command not found

证明php命令无法执行,我们可以查找php的真实路径,直接运行真实路径的php

通过 find - name php 查询出php执行文件所在的路径(bin文件夹中的php)

队列开启教程二 - 图11

下面执行队列的时候,可以用全路径的php来执行,如下图,原来的php用 真正的路径代替

队列开启教程二 - 图12

如果您的社区团购系统安装的是php5.6版本,但是输入 php -v,提示的默认执行是7.2的版本,或者安装的7.2版本,php -v提示5.6版本

这种情况我们就需要参考上面的方法,查到php7.2或者5.6的真实路径,通过绝对路径地址代替php命令。

二、 队列开启命令执行后,无后台进程怎么办?

队列开启教程二 - 图13

很多人执行完上面的命令后,出来一个数字,但是查询进程没有发现队列进程

这就证明队列没有正常开启。

造成这个情况的原因有几个,首先是参考基础条件中宝塔环境需要删除几个禁用函数 ,进行操作。

如果还是不能正常开启,可以输入下面的命令 php /www/wwwroot/xxxxxx/yii ,直接运行yii文件,看看有什么报错。

队列开启教程二 - 图14

如上图,提示exec()函数被禁用的原因,如果您无法确认具体是什么原因,请截图发我们排查。

解除后,如果执行该命令,能返回下图的 黄色和绿色文字,则证明队列环境已经正常,可继续开启队列。

队列开启教程二 - 图15

三、amh环境,php -cli 模式,提示没有加载swoole_loader怎么办?

把php.ini配置文件,复制到etc目录中一份

队列开启教程二 - 图16

队列开启教程二 - 图17