ThinkPHP出现General error: 2006 MySQL server has gone away的解决方法

2018-02-08 07:53:33来源:cnblogs.com作者:DragonDean人点击

分享

错误:

#13 {main}SQLSTATE[HY000]: General error: 2006 MySQL server has gone away
FILE: /ThinkPHP/Library/Think/Db/Driver.class.php(169)


原因分析:

本次错误提示是在cli模式运行,隔一段时间就会出现,查询资料后发现mysql默认没隔8个小时(2880000秒)就会断开


解决方案,解决方式找了三个

方法1

  配置mysql.cnf(windows系统则是my.ini),指定wait_timeout和interactive_timeout,设置一个比较大的值,比如一年(86400*365)。

方法2

  链接后通过执行命令来指定本次链接的wait_timeout和interactive_timeout,原理跟【1】一样,只不过这种方式只影响本次链接,方式【1】会影响所有链接。

  但是thinkphp已经封装好了数据库驱动,所以不好单独指定某一次。我的做法是判断php_sapi,如果是cli则设置wait_timeout和interactive_timeout

// ThinkPHP/Library/Think/Db/Driver.class.php 第 105行if(PHP_SAPI == 'cli'){     $query = $this->linkID[$linkNum]->prepare("set session wait_timeout=31536000,interactive_timeout=31536000,net_read_timeout=10000");     $query->execute();}

方法3

既然是超时断开了,那我们就可以采取断线重连的方式

// ThinkPHP/Library/Think/Db/Driver.class.php 第 105行
$this->linkID[$linkNum]->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);$this->linkID[$linkNum]->setAttribute(PDO::ATTR_STRINGIFY_FETCHES, false);$this->linkID[$linkNum]->setAttribute(PDO::ATTR_EMULATE_PREPARES, false);
// ThinkPHP/Library/Think/Db/Driver.class.php 第159行(query方法) 和 220行(execute方法)try {            $this->PDOStatement = $this->_linkID->prepare($str);        } catch (/PDOException $e) {            // 断线重连            if ($e->errorInfo[1] == 2006 || $e->errorInfo[1] == 2013) {                echo "---> db reconnecting.../n";                $this->linkID = array();                $this -> _linkID = null;                $this->initConnect(false);                $this->PDOStatement = $this->_linkID->prepare($str);            }        }

最新文章

123

最新摄影

微信扫一扫

第七城市微信公众平台