首页 > 数据库 > mysql教程 > MySQL server has gone away_MySQL

MySQL server has gone away_MySQL

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
发布: 2016-06-01 13:35:30
原创
917 人浏览过

bitsCN.com

今天遇到一个Mysql的问题:执行update时报错:MySQL server has gone away

由于是Linux后台服务程序,需要7*24运行,但程序在初始化时进行了DB的open操作之后,就进入了for(;;),遇到某个异常导致数据库操作句柄断开,却又没有相应的出错处理,导致程序一直报错。

下面是关于使用mysql_ping函数之后的改进,

这是我的的数据库操作类中间的一个函数
function ping()

{
  if(!mysql_ping($this->link))

   {
    mysql_close($this->link); //注意:一定要先执行数据库关闭,这是关键
    $this->connect($this->t_dbhost,$this->t_dbuser,$this->t_dbpw,$this->t_dbname,$this->t_pconnect);
    }
}


我需要调用这个函数的代码可能是这样子的
for($i=0;$i$str=file_get_contents(’xxx.xxx,xxx,xxxx’);
}
$db->ping(); //经过前面的网页抓取后,或者会导致数据库连接关闭,检查并重新连接
$db->query(’select * from table’);
ping()这个函数先检测数据连接是否正常,如果被关闭,整个把当前脚本的MYSQL实例关闭,再重新连接。
经过这样处理后,可以非常有效的解决MySQL server has gone away这样的问题,而且不会对系统造成额外的开销。

bitsCN.com
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
javascript - promise.all mongoose操作数据库
来自于 1970-01-01 08:00:00
0
0
0
外网访问内网数据库,如何操作?
来自于 1970-01-01 08:00:00
0
0
0
java - spring操作数据库显示中文乱码的问题?
来自于 1970-01-01 08:00:00
0
0
0
求symfony 1.4 propel 操作多个数据库 方法
来自于 1970-01-01 08:00:00
0
0
0
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板