【PHP】关于守护进程报错:SQLSTATE[HY000]: General error: 2006 MySQL server has gone away

文章目录

概要

前段时间,公司的fastadmin项目要加入会员升级功能,我想可以把这些繁琐的升级判断做出守护进程,相当于丢到子线程中慢慢消化,肯定会提升代码执行效率。但完善了守护进程后,发现上线几天后,守护进程c操作了数据库,就开始报异常:SQLSTATE[HY000]: General error: 2006 MySQL server has gone away,一看这个错就是数据库连接出了问题。

技术细节

在fastadmin或者TP中,操作数据库一般用两种方式,一种是建model类,然后通过model对象操作数据库,还有一种方便快捷的方式,就是基于Db::name('table_name')的方式操作数据库,如果守护进程中这两种方式都涉及了,那么需要区分解决:

基于model类:

在database.php中加 :

php 复制代码
  'break_reconnect' => true,

📌 含义:

SQL 执行失败时,自动重连一次再执行

如果用Db::name的方式,可以在守护进程方法开始前,先运行一段代码:

php 复制代码
 try {
    Db::query("SELECT 1");
 } catch (\Exception $e) {
      Db::clear();
 }

实际作用是:

主动探测数据库连接是否还活着

SELECT 1 是最轻量的心跳 SQL

如果抛异常(比如 MySQL server has gone away)

说明当前 PDO 连接已经是 死连接

Db::clear()

清空 ThinkPHP 当前进程里缓存的连接

下一次 SQL 会 重新建连接

👉 在 常驻进程 / 长时间脚本 中,这是一个非常必要的防御手段。

相关推荐
郝学胜-神的一滴20 小时前
超越Spring的Summer(一): PackageScanner 类实现原理详解
java·服务器·开发语言·后端·spring·软件构建
摇滚侠20 小时前
Java,举例说明,函数式接口,函数式接口实现类,通过匿名内部类实现函数式接口,通过 Lambda 表达式实现函数式接口,演变的过程
java·开发语言·python
阿里嘎多学长20 小时前
2026-02-03 GitHub 热点项目精选
开发语言·程序员·github·代码托管
Tony Bai20 小时前
“Go 2,请不要发生!”:如果 Go 变成了“缝合怪”,你还会爱它吗?
开发语言·后端·golang
打工的小王20 小时前
java并发编程(七)ReentrantReadWriteLock
java·开发语言
lang2015092821 小时前
Java并发革命:JSR-133深度解析
java·开发语言
禹凕21 小时前
Python编程——进阶知识(面向对象编程OOP)
开发语言·python
abluckyboy21 小时前
基于 Java Socket 实现多人聊天室系统(附完整源码)
java·开发语言
毅炼21 小时前
Java 基础常见问题总结(3)
java·开发语言
m0_7482299921 小时前
PHP简易聊天室开发指南
开发语言·php