我正在开发 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();
}