zoukankan      html  css  js  c++  java
  • MySQL server has gone away

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

  • 相关阅读:
    模拟乒乓球双打和单打比赛
    关于zip内置函数的应用及在 Python 2 和 3 的不同之处
    计算文本平均列数
    四则运算
    Python跳一跳小游戏
    数据库
    类和正则表达
    带进度条的圆周率计算
    球队预测
    自己的第一个网页
  • 原文地址:https://www.cnblogs.com/makeup1122/p/2973140.html
Copyright © 2011-2022 走看看