Yii2 MySQL 服务器已经消失了


Yii2 MySQL server has gone away

我正在开发 Yii2 应用程序。有一个控制台脚本执行时间很长,并且失败并显示错误:MySQL服务器已消失

根据日志,它会在 6-7 秒后在没有与数据库通信的情况下引发异常(它执行一些工作,如果需要,应该更新表)。

我在数据库配置中添加了PDO超时:

'attributes' => [
    PDO::ATTR_TIMEOUT => 600,
],

我也检查了MySQL超时变量,但它们似乎很好:

mysql> show variables like '%timeout%';
+----------------------------+--------+
| Variable_name              | Value  |
+----------------------------+--------+
| connect_timeout            | 10     |
| delayed_insert_timeout     | 300    |
| innodb_lock_wait_timeout   | 50     |
| innodb_rollback_on_timeout | OFF    |
| interactive_timeout        | 259200 |
| net_read_timeout           | 30     |
| net_write_timeout          | 60     |
| slave_net_timeout          | 3600   |
| table_lock_wait_timeout    | 50     |
| wait_timeout               | 259200 |
+----------------------------+--------+
10 rows in set (0.00 sec)

我尝试像这样在控制器中重新连接:

Yii::$app->db->close();
Yii::$app->db->open();

但这并没有帮助。你知道我做错了什么吗?

谢谢

我通过添加操作来解决

Yii::$app->db->createCommand('SET SESSION wait_timeout = 28800;')->execute();

我通过添加解决了

max_allowed_packet = 128M
wait_timeout=3600
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

在 mysql 的 my.cnf 中

您需要

使用try {...}catch(){...}语句手动处理它。

try {
        'Yii::$app->db->createCommand("DO 1")->execute();
    } catch (Exception $e) {
        'Yii::$app->db->close();
        'Yii::$app->db->open();
    }