以此难点普通在laravel中表现为挨近上边的老大:

ThinkPHP现身General error: 二〇〇五 MySQL server has gone away的减轻情势,thinkphpgeneral

错误:

#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);
            }
        }

 

error: 2005 MySQL server has
gone away的减轻办法,thinkphpgeneral 错误: #13
{main}SQLSTATE[HY000]: General error: 2006 MySQL server has gone away
FI…

 

local.ERROR: SQLSTATE[HY000] [2006] MySQL server has gone away
{“exception”:”[object] (PDOException(code: 2006): SQLSTATE[HY000]
[2006] MySQL server has gone away at…

网站地图xml地图