yii2 mysql gone away_yii2 console MySQL server has gone away

一.问题:

现在有1个使用yii2的console执行的php脚本,该脚本一直在后台执行.

追踪输出日志发现报:

2006 MySQL server has gone away

二.主要代码如下:

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();

}

三.场景:

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

四.分析:

我的insert操作只是插入一个int型字段和一个时间戳,所以问题不会处在这个insert执行时间过长上。

由于间隔时间有可能太长,超过了mysql的wait_timeout,导致出现这个:

MySQL server has gone away

五.yii2怎么解决?

1.本人没有修改mysql.ini的timeout参数权限,所以这种解决办法不可行

2.解决思路也比较简单:在每次Insert之前判断db connection是否active,否则重新连接,那我的代码为什么不能解决这个问题?该怎样写?注意用yii2类解决

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

回复内容:

一.问题:

现在有1个使用yii2的console执行的php脚本,该脚本一直在后台执行.

追踪输出日志发现报:

2006 MySQL server has gone away

二.主要代码如下:

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();

}

三.场景:

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

四.分析:

我的insert操作只是插入一个int型字段和一个时间戳,所以问题不会处在这个insert执行时间过长上。

由于间隔时间有可能太长,超过了mysql的wait_timeout,导致出现这个:

MySQL server has gone away

五.yii2怎么解决?

1.本人没有修改mysql.ini的timeout参数权限,所以这种解决办法不可行

2.解决思路也比较简单:在每次Insert之前判断db connection是否active,否则重新连接,那我的代码为什么不能解决这个问题?该怎样写?注意用yii2类解决

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

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值