12

我在 Magento 网站上工作,我收到此错误:

SQLSTATE[HY000]: General error: 2006 MySQL server has gone away on running 
cron job magento

我有时只会收到此错误。

<?php
class Namespace_Module_Model_Observer 
{
  public function importemails(Varien_Event_Observer $observer)
  {
    echo "Hi Dear";exit();

    /* connect to gmail */
    $hostname = '{imap.gmail.com:993/imap/ssl}INBOX';
    $username = 'myid@gmail.com';
    $password = 'mypass';

    /* try to connect */
    $inbox = imap_open($hostname,$username,$password) 
        or die('Cannot connect to Gmail: ' . imap_last_error());

    /* grab emails */
    $emails = imap_search($inbox,'ALL');

    /* if emails are returned, cycle through each... */
    if($emails) {

      /* begin output var */
      $output = '';

      /* put the newest emails on top */
      rsort($emails);

      /* for every email... */
      foreach($emails as $email_number) {

        /* get information specific to this email */
        $overview = imap_fetch_overview($inbox,$email_number,0);
        $message = imap_fetchbody($inbox,$email_number,2);

        /* output the email header information */
        $output.= 
          '<div class="toggler '.($overview[0]->seen ? 'read' : 'unread').'">';
        $output.= '<span class="subject">'.$overview[0]->subject.'</span> ';
        $output.= '<span class="from">'.$overview[0]->from.'</span>';
        $output.= '<span class="date">on '.$overview[0]->date.'</span>';
        $output.= '</div>';

        /* output the email body */
        $output.= '<div class="body">'.$message.'</div>';
      }
      echo $output;
    } 

    /* close the connection */
    imap_close($inbox);
  }  
}

这段代码工作了几个小时,然后它给出了这个错误。错误是什么意思?

4

6 回答 6

27

如果您在打开连接后的某个时间尝试发送查询,则数据库连接有超时,这将导致此错误。通常的情况是:

  • 打开数据库连接
  • 从数据库中获取一些数据
  • 做一些事情,例如发送电子邮件(比数据库连接超时时间长)
  • 使用相同的连接查询数据库
  • 错误:MySQL 服务器已消失

那么 - 解决方案是什么?您可以简单地增加超时时间,但这很丑陋,并且当您网站的流量增加时可能会导致问题。最好的解决方案是关闭您的数据库连接,然后像这样重新打开它:

  • 打开数据库连接
  • 从数据库中获取一些数据
  • 关闭数据库连接
  • 做一些事情,例如发送电子邮件(比数据库连接超时时间长)
  • 打开新的数据库连接
  • 使用相同的连接查询数据库
  • 关闭数据库连接

这里有更多信息: http ://dev.mysql.com/doc/refman/5.0/en/gone-away.html

于 2013-08-30T07:19:46.043 回答
0

我没有任何超时问题。

我将 fclose(STDERR) 行从我的主文件移动到一个包含的文件,这开始发生。

SQLSTATE[HY000]:一般错误:2006 MySQL 服务器已消失

我将线路移回原来的位置,问题就消失了。

基本上,从包含的文件中关闭 STDERR 似乎会产生一些疯狂的影响。

于 2014-04-06T00:10:42.133 回答
0

如果您在使用 phpsh 解释器时遇到此错误。 我可以使用 phpsh 和一个新的 shell 来重现这个错误。

SQLSTATE[HY000]: General error: 2006 MySQL server has gone away 

在 phpsh 解释器中使用此命令:

php> $result = $conn->query('select psetid from psetproblems')->fetchAll();

解释:

此错误是 MySQL 超时错误。要么您在创建连接然后实际使用它之间等待了太长时间,要么您的某个命令出错并破坏了连接。最简单的解决方案是停止,重新启动一切,不要运行引发错误的命令,并且快速执行。它应该工作。

解决方案

重新启动您的解释器。不要提交错误并通过解释器更快地发出命令。

您可以增加 PHP 的 MySQL 连接的超时长度。然后,您可以在创建连接和使用它之间等待更长的时间。

于 2014-02-14T20:31:58.240 回答
0

使用共享主机时,您还可以查看索引表大小。它可能会占用很多空间,因此您也可能会得到“mysql server away”。

于 2014-08-14T09:05:16.990 回答
0

我以前遇到过这个错误。就我而言,这是由于数据库太大,5 年的数据超过 18GB。

唯一对我有用的解决方案是转储所有这些数据并创建一个新数据库。

于 2015-06-30T04:08:43.613 回答
0

如果您有任何操作在 Magento DB 上超过 20 秒(我遇到过这样的 wait_timeout=20 的共享主机),您必须关闭数据库连接。Magento 将在下次调用 DB 时创建新连接。

    Mage::getSingleton('core/resource')->getConnection('read')->closeConnection();
于 2016-02-14T14:32:35.383 回答