当前位置: 凤凰彩票登陆 > MySQL数据库 > 正文

0后密码验证方法难题,away的消除办法

时间:2019-10-09 13:05来源:MySQL数据库
  ThinkPHP出现General error: 2006 MySQL server has gone away的解决方法,thinkphpgeneral 错误: #13 {main}SQLSTATE[HY000]: General error: 2006 MySQL server has goneaway 凤凰新闻手机版下载,FILE: ThinkPHPLibraryThinkDbDr

 

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

错误:

#13 {main}SQLSTATE[HY000]: General error: 2006 MySQL server has gone away
凤凰新闻手机版下载,FILE: ThinkPHPLibraryThinkDbDriver.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

// ThinkPHPLibraryThinkDbDriver.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

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

// ThinkPHPLibraryThinkDbDriver.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);

// ThinkPHPLibraryThinkDbDriver.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: 2006 MySQL server has gone away的解决方法,thinkphpgeneral 错误: #13 {main}SQLSTATE[HY000]: General error: 2006 MySQL server has gone away FI...

SET GLOBAL  max_allowed_packet=67108864;

 

如果我们单看mysql提示MySQL server has gone away就是由于种种原因导致mysql当机了,导致MySQL server has gone away的原因有很多种,下面我来总结一下。

这个问题通常在laravel中表现为类似下边的异常:

我自己人的经历

找到你的my.cnf,在[mysqld]下增加一行

In the MySQL server installation directory,
in my.ini file, add the following line under [mysqld] in SERVER SECTION.

 1 default-authentication-plugin=mysql_native_password 

max_allowed_packet = 16M

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

这个错误信息很好的描述了是数据库超时引起的。以前听前辈说过,应该是wait_timeout环境变量设置的有问题。可是查看后,发现wait_timeout设的好高啊,为28800,不应该出问题啊。无解。

Save the file and restart MySQL server.

In the my.cnf file, change the default
max_allowed_packet = 1M
to
max_allowed_packet = 16M

Error: SQLSTATE[HY000]: General error: 2006 MySQL server has gone away

那我改下就行了 嘿嘿

 代码如下

复制代码

In Windows:

In Linux:

就可以了,不是max_allowed_packet越大越好哦,大家可根据自己人情况来设置。

set global wait_timeout = 120;

server has gone away就是由于种种原因导致mysql当机了,导致MySQL server has gone away的原因有很多种,下面我来总结一下。...

 代码如下

总结解决了,但很多MySQL server has gone away都与此问题无关了,都有和max_allowed_packet有关了

Error Code: 2006 – MySQL server has gone away

导入数据库的时候 SQLyog 报错了

搜了下,说是max_allowed_packet (MySQL的一个参数)设置的值不够大。

$ cp /usr/share/mysql/my-xxx.cnf /etc/my.cnf

今天导入.sql文件时出现了Error Code: 2006 – MySQL server has gone away错误,原来是导入的sql文件大于系统默认的max_allowed_packet的值,查了很多修改配置文件的,但是没有找到my.cfg文件,修改其他文件不管用,所以直接使用sql语句来修改:

头回来后,诉说。头笑而不语,让我只看,别说话。

xxx can be small, medium, large, huge … depending on the requirement.

复制代码

Copy the my-xxx.cnf file from /usr/share/mysql to /etc as my.cnf

show global variables;

复制代码

先简单介绍一下这个新手卡录入后台,这个后台是提供给产品人员使用。可以向某个游戏的某个特定分区批量录入新手卡信息,方便玩家获取。后台设置的一次性最大录入量为500。

 代码如下

先看日志吧,报错的内容和日志的相同:

编辑:MySQL数据库 本文来源:0后密码验证方法难题,away的消除办法

关键词: