首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Yii2 MySQL服务器已经消失。

Yii2 MySQL服务器已经消失。
EN

Stack Overflow用户
提问于 2014-11-16 21:14:26
回答 2查看 7.7K关注 0票数 4

我正在开发Yii2应用程序。有一个控制台脚本执行时间很长,但由于出错而失败:MySQL服务器已经离开了

根据日志,它在6-7秒后抛出一个异常,而不与数据库通信(它做了一些工作,如果需要,应该更新一个表)。

我在db配置中添加了PDO超时:

代码语言:javascript
复制
'attributes' => [
    PDO::ATTR_TIMEOUT => 600,
],

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

代码语言:javascript
复制
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)

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

代码语言:javascript
复制
Yii::$app->db->close();
Yii::$app->db->open();

但没什么用。你知道我做错了什么吗?

谢谢

EN

回答 2

Stack Overflow用户

发布于 2016-06-01 17:14:28

我把动作加进去解决了

代码语言:javascript
复制
Yii::$app->db->createCommand('SET SESSION wait_timeout = 28800;')->execute();
票数 6
EN

Stack Overflow用户

发布于 2014-12-08 05:12:08

我通过添加

代码语言:javascript
复制
max_allowed_packet = 128M
wait_timeout=3600
sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES

在mysql的my.cnf中

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/26962120

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档