mysql - php查询报错Error while sending QUERY packet. PID=xxx

查看:500
本文介绍了mysql - php查询报错Error while sending QUERY packet. PID=xxx的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

背景:使用Yii2命令行模式开启脚本监控rabbitmq队列,当队列有订单信息,执行查询,更新操作(相当于PHP文件写个查询,更新,使用命令行启动)

问题:一开始监控没有问题,每过一段时间会抛出错误

> Error while sending QUERY packet. PID=25370. The SQL being executed was: 一句sql语句(此sql直接执行没有错误).

已经找到问题解决方案,由于我等待消息队列是一个长连接,而我在等待回调前有个数据库连接,数据库的wait_timeout=28800,所以只要下一条消息离上一条消息超过8小时,就会出现这个错误,我把wait_timeout设置成10,并且捕获异常,发现真实的报错是 MySQL server has gone away ,
所以只要在把等待回调前那次数据库连接主动close掉就可以解决问题

解决方案

已经找到问题解决方案,由于我等待消息队列是一个长连接,而我在等待回调前有个数据库连接,数据库的wait_timeout=28800,所以只要下一条消息离上一条消息超过8小时,就会出现这个错误,我把wait_timeout设置成10,并且捕获异常,发现真实的报错是 MySQL server has gone away ,
所以只要在把等待回调前那次数据库连接主动close掉就可以解决问题

这篇关于mysql - php查询报错Error while sending QUERY packet. PID=xxx的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆