扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
这篇“怎么解决thinkphp-queue的相关问题”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“怎么解决thinkphp-queue的相关问题”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望大家通过这篇文章有所收获,下面让我们一起来看看具体内容吧。
创新互联主营石狮网站建设的网络公司,主营网站建设方案,成都app软件开发,石狮h5重庆小程序开发公司搭建,石狮网站营销推广欢迎石狮等地区企业咨询
thinkphp属于一种免费的开发框架,能够用于开发前端网页,最早thinkphp是为了简化开发而产生的,thinkphp同时也是遵循Apache2协议,最初是从Struts演变过来,也把国外一些好的框架模式进行利用,使用面向对象的开发结构,兼容了很多标签库等模式,它能够更方便和快捷的开发和部署应用,当然不仅仅是企业级应用,任何php应用开发都可以从thinkphp的简单、兼容和快速的特性中受益。
队列任务运行一段时间,出现:SQLSTATE[HY000]: General error: 2006 MySQL server has gone away报错。
解决方法和分析:
配置文件database.php
中配置断线重连:
// 是否需要断线重连 'break_reconnect' => true, // 断线标识字符串 'break_match_str' => ['2006'],
配置后虽然日志中会出现另一个报错:PDO::prepare(): send of 60 bytes failed with errno=32 Broken pipe,但并不影响程序运行结果。因为断线重连后,程序都会抛出错误:
...} catch (\PDOException $e) { if ($this->isBreak($e)) { return $this->close()->query($sql, $bind, $master, $pdo); } throw new PDOException($e, $this->config, $this->getLastsql());} catch (\Throwable $e) { if ($this->isBreak($e)) { return $this->close()->query($sql, $bind, $master, $pdo); } throw $e;} catch (\Exception $e) { if ($this->isBreak($e)) { return $this->close()->query($sql, $bind, $master, $pdo); } throw $e;}
一般情况下,可以使用supervisor监护队列进程。配合docker使用的话,大概有几方案:
1.将supervisor安装到php服务所在的容器中
2.跑一个新的容器来运行队列任务(不用supervisor,容器本身是一个daemon)
3.直接在现有的php容器运行队列任务(命令行使用–daemon选项)
方法一supervisor参考配置(放在/etc/supervisor/conf.d, 文件命名为{file-name}.conf):
[program:my_queue_name]process_name=%(program_name)s_%(process_num)02d command=php /path/to/think queue:work --queue=your-queue-name --sleep=3 --daemon autostart=trueautorestart=truenumprocs=1user=root stopasgroup=truekillasgroup=trueredirect_stderr=truestdout_logfile=/path/to/your-queue.log
方法二新开一个镜像参考配置(在docker-compose.yml中添加服务):
php-queue: container_name: queue image: docker_php-fpm73 restart: always command: php path/to/think queue:work --sleep=3 volumes: - ../project:/var/www/html - ./conf/php:/usr/local/etc/php - ./conf/php/conf.d:/usr/local/etc/php/conf.d - ./conf/supervisor:/etc/supervisor/conf.d networks: - mysql - nginx
方法三有点hack,为了不大改线上环境,最后使用方法三(在host机子操作)。
启动:docker exec -i php7 php /path/to/think queue:work --queue=my-queue-name --sleep=3 --daemon
重启:docker exec -i php7 php /path/to/think queue:restart
(重启后发现队列进程消失了),然后再启动
查看队列进程: ps -aux | grep queue
有时候某些原因程序出错,会有大量日志生成,最好调整下日志,单独出来。在配置文件config/queue.php
开头添加:
use think\facade\Log;Log::init([ 'single' => 'queue', 'file_size' => 1024 * 1024 * 10, 'level' => ['error'],]);
日志将输出到runtime
目录的queue-cli.log
文件
感谢你的阅读,希望你对“怎么解决thinkphp-queue的相关问题”这一关键问题有了一定的理解,具体使用情况还需要大家自己动手实验使用过才能领会,快去试试吧,如果想阅读更多相关知识点的文章,欢迎关注创新互联行业资讯频道!
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流