Heim > Backend-Entwicklung > PHP-Tutorial > yii2 console MySQL server has gone away

yii2 console MySQL server has gone away

WBOY
Freigeben: 2016-06-06 20:11:15
Original
2132 Leute haben es durchsucht

一.问题:
现在有1个使用yii2的console执行的php脚本,该脚本一直在后台执行.
追踪输出日志发现报:

<code>2006 MySQL server has gone away
</code>
Nach dem Login kopieren
Nach dem Login kopieren

二.主要代码如下:

<code>try{
Yii::$app->db->open();
    if (Yii::$app->db->getIsActive()) {
       // 做insert操作
    }
}catach(\yii\db\Exception $e){
   var_dump($e);
  // 重新连接
 Yii::$app->db->close();
 Yii::$app->db->open();
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

三.场景:

这个php脚本一直在后台执行,当有数据过来时,执行insert操作,无数据过来不执行insert操作。可能昨天18:00来条数据,然后insert成功,然后到第二天上午10:00才来另一条数据;也可能间隔会很小;

四.分析:
我的insert操作只是插入一个int型字段和一个时间戳,所以问题不会处在这个insert执行时间过长上。
由于间隔时间有可能太长,超过了mysql的wait_timeout,导致出现这个:

<code>MySQL server has gone away
 </code>
Nach dem Login kopieren
Nach dem Login kopieren

五.yii2怎么解决?
1.本人没有修改mysql.ini的timeout参数权限,所以这种解决办法不可行
2.解决思路也比较简单:在每次Insert之前判断db connection是否active,否则重新连接,那我的代码为什么不能解决这个问题?该怎样写?注意用yii2类解决

  1. github上有相关讨论,但是没有说一个标准的解决办法.

回复内容:

一.问题:
现在有1个使用yii2的console执行的php脚本,该脚本一直在后台执行.
追踪输出日志发现报:

<code>2006 MySQL server has gone away
</code>
Nach dem Login kopieren
Nach dem Login kopieren

二.主要代码如下:

<code>try{
Yii::$app->db->open();
    if (Yii::$app->db->getIsActive()) {
       // 做insert操作
    }
}catach(\yii\db\Exception $e){
   var_dump($e);
  // 重新连接
 Yii::$app->db->close();
 Yii::$app->db->open();
}
</code>
Nach dem Login kopieren
Nach dem Login kopieren

三.场景:

这个php脚本一直在后台执行,当有数据过来时,执行insert操作,无数据过来不执行insert操作。可能昨天18:00来条数据,然后insert成功,然后到第二天上午10:00才来另一条数据;也可能间隔会很小;

四.分析:
我的insert操作只是插入一个int型字段和一个时间戳,所以问题不会处在这个insert执行时间过长上。
由于间隔时间有可能太长,超过了mysql的wait_timeout,导致出现这个:

<code>MySQL server has gone away
 </code>
Nach dem Login kopieren
Nach dem Login kopieren

五.yii2怎么解决?
1.本人没有修改mysql.ini的timeout参数权限,所以这种解决办法不可行
2.解决思路也比较简单:在每次Insert之前判断db connection是否active,否则重新连接,那我的代码为什么不能解决这个问题?该怎样写?注意用yii2类解决

  1. github上有相关讨论,但是没有说一个标准的解决办法.

Verwandte Etiketten:
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage