1. 队列优势
任务执行流畅,无需等待。如团长批量发送提货通知(比如500条,正常操作发送完需要等待2分钟)。如开启了队列后,团长点击一下发送,后台队列服务就开始一条条发送,无需团长在操作页面等待发送完成。
可减轻秒杀环节高并发对服务器的压力。
可执行一些定时的任务。
2. 队列功能
①团员收货消息群发 ②自动关闭订单 ③自动收货 ④自动上下架 ⑤秒杀分流 ⑥拼团自动退款和关闭订单 等后续增加的新功能。
3. 基础条件
1. swoole扩展正常安装
社区团购plus系统打开正常,并且未提示swoole_loader未安装
2. 宝塔环境需要删除几个禁用函数、非宝塔的可以在php.ini中删除“disable_functions”中对应的函数
如果您为宝塔环境,请在“软件管理”—>“PHP -7.2”设置页—禁用函数中,删除如下图的5个函数,否则无法开启队列。
切记,每次在宝塔更新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文件 ”
这就是我们队列开启的核心语句。
如图,执行完之后,会提示一条数字
我们需要确认,队列是否在后台正常运行,输入进程查询命令 ps -aux|grep yii
如果查询结果如上图,则队列没有正在在后台运行,请最下方“队列开启命令执行后无后台进程”查看调试方法。
↑↑↑ 如果查询结果如上图,可看到此次查询到了 yii文件在后台运行的 queue/listen 命令,证明您的队列已经正常开启!
仅此还不行,我们需要把队列设置为开机自动启动。
先执行此命令,开启自动启动功能 chmod +x /etc/rc.d/rc.local
然后编辑启动脚本 vi /etc/rc.local ,把队列开启命令放入启动脚本
然后重启服务器,使用 ps -aux|grep yii 查询队列是否开启,如正常开启,则证明开启启动已生效。
5. 常见问题及解决方法
一、 php命令无法执行或版本不一致怎么办?
在某些集成环境下,php命令没有设置,无法自动运行,如下图。
此图 执行 php -v 下面提示 command not found
证明php命令无法执行,我们可以查找php的真实路径,直接运行真实路径的php
通过 find - name php 查询出php执行文件所在的路径(bin文件夹中的php)
下面执行队列的时候,可以用全路径的php来执行,如下图,原来的php用 真正的路径代替
如果您的社区团购系统安装的是php5.6版本,但是输入 php -v,提示的默认执行是7.2的版本,或者安装的7.2版本,php -v提示5.6版本
这种情况我们就需要参考上面的方法,查到php7.2或者5.6的真实路径,通过绝对路径地址代替php命令。
二、 队列开启命令执行后,无后台进程怎么办?
很多人执行完上面的命令后,出来一个数字,但是查询进程没有发现队列进程
这就证明队列没有正常开启。
造成这个情况的原因有几个,首先是参考基础条件中宝塔环境需要删除几个禁用函数 ,进行操作。
如果还是不能正常开启,可以输入下面的命令 php /www/wwwroot/xxxxxx/yii ,直接运行yii文件,看看有什么报错。
如上图,提示exec()函数被禁用的原因,如果您无法确认具体是什么原因,请截图发我们排查。
解除后,如果执行该命令,能返回下图的 黄色和绿色文字,则证明队列环境已经正常,可继续开启队列。
三、amh环境,php -cli 模式,提示没有加载swoole_loader怎么办?
把php.ini配置文件,复制到etc目录中一份