yii2 console MySQL server has gone away

WBOY
リリース: 2016-06-06 20:11:15
オリジナル
2048 人が閲覧しました

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

<code>2006 MySQL server has gone away
</code>
ログイン後にコピー
ログイン後にコピー

二.主要代码如下:

<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>
ログイン後にコピー
ログイン後にコピー

三.场景:

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

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

<code>MySQL server has gone away
 </code>
ログイン後にコピー
ログイン後にコピー

五.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>
ログイン後にコピー
ログイン後にコピー

二.主要代码如下:

<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>
ログイン後にコピー
ログイン後にコピー

三.场景:

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

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

<code>MySQL server has gone away
 </code>
ログイン後にコピー
ログイン後にコピー

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

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

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!