ThinkPHP出現General error: 2006 MySQL server has gone away的解決方法


錯誤:

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

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM