间歇性 MySQL 服务器已消失错误

Posted

技术标签:

【中文标题】间歇性 MySQL 服务器已消失错误【英文标题】:intermittent MySQL server has gone away error 【发布时间】:2012-08-22 09:43:02 【问题描述】:

我一直在摸索,试图找出导致脚本间歇性错误的原因。错误是:SQLSTATE[HY000]: General error: 2006 mysql server has gone away。

我下面的脚本是执行 curl 的函数的一部分,它从 JSON 响应中获取一些值,然后将它们写入表中。我会说 80% 的时间它工作正常,然后其他 20% 我得到服务器消失错误。我无法确定导致它出错的任何趋势,它似乎只是随机的。任何想法为什么我可能会收到此错误?感谢您查看此内容

    ...
    //post via cURL 
    $ch = curl_init( $url );
    $timeout = 500;
    curl_setopt( $ch, CURLOPT_POST, 1);
    curl_setopt( $ch, CURLOPT_POSTFIELDS, $myvars);
    curl_setopt( $ch, CURLOPT_FOLLOWLOCATION, 1);
    curl_setopt( $ch, CURLOPT_CONNECTTIMEOUT, $timeout);
    curl_setopt( $ch, CURLOPT_HEADER, 0);
    curl_setopt( $ch, CURLOPT_RETURNTRANSFER, 1);
    $this->response = curl_exec( $ch );
    $this->json_decoded = json_decode($this->response);
    $this->full = print_r($this->json_decoded, true);
    $client_leadid = $this->json_decoded->Parameters->lead_id;
    $client_status = $this->json_decoded->Status;   
    $length = curl_getinfo($ch);
    curl_close($ch);

    //record in DB
    $insert = $this->full.' | '.$url.' | '.$myvars.' | '.$this->date . ' | Time Taken: '.$length['total_time'];
    $db->exec("UPDATE table SET client_resp = '$insert' WHERE global_id = '$this->leadid' LIMIT 1");
    $db->exec("UPDATE table SET client_leadid = '$client_leadid' WHERE global_id = '$this->leadid' LIMIT 1");

【问题讨论】:

你能从 MySQL 错误日志中读到什么? 您可能需要查看找到的原因清单here。 您可以将查询次数减少 50%,这可能会对您面临的 renadom 角色产生积极影响。调试愉快,因为到目前为止您分享的不是问题,而是邀请猜测。当工作/停止工作时,网络连接会发生什么。你监控过这些吗?错误日志呢?服务器负载呢?实际上,请以纯文本形式提供查询,而不是 php 代码。 服务器已消失:服务器已消失。 (或者,由于某种原因无法联系到。) @tadman - 是的,我知道,PDO 还是新手,会解决这个问题!谢谢指出 【参考方案1】:

这可能是因为您的 CURL 请求花费的时间比 mysql 连接超时时间长

要么 1) 为 CURL 设置一个请求超时,以便它在错误时更快地死掉(CURLOPT_CONNECTTIMEOUT 仅用于连接 - CURLOPT_TIMEOUT 用于请求的总长度,如果服务器没有及时响应,它将停止) 2) 调高 mysql 空闲超时,以防止服务器因未发送查询而断开连接 3)检测错误并自动重新连接mysql

mysql> show variables like "%timeout%";
+--------------------------+-------+
| Variable_name            | Value |
+--------------------------+-------+
| connect_timeout          | 5     |
| delayed_insert_timeout   | 300   |
| innodb_lock_wait_timeout | 50    |
| interactive_timeout      | 28800 |
| net_read_timeout         | 30    |
| net_write_timeout        | 60    |
| slave_net_timeout        | 3600  |
| table_lock_wait_timeout  | 50    |
| wait_timeout             | 28800 |
+--------------------------+-------+
9 rows in set (0.00 sec)

wait_timeout 和 interactive_timeout 是你关心的两个

【讨论】:

谢谢,我已经增加了 mysql 的超时时间,正在等待是否能解决问题。我不知道这些设置,所以感谢您的提示! 您建议“检测错误并自动重新连接”您能否提供一些有关如何执行此操作的指导?我会使用 try ... catch (PDOException $err) [reconnect_here] 吗?我会用什么代替 [reconnect_here]?感谢您的帮助... Rob- 这取决于您的代码。如果您有自己的 DB 类,其中包含 query() 函数 - 您将捕获错误,重新连接,然后再次调用 query()重试的相同参数(直接返回结果 - 考虑递归)如果您直接在代码中编写数据库查询,您将不得不以艰难的方式进行(重新连接 + 重新运行 try 块中的查询.. . 但如果服务器在第二次尝试时仍处于关闭状态,请确保您捕捉到错误) - 如果您能提供帮助,我不建议嵌套 try catch 块 eww- 间隔很好- 我猜你不能在 cmets 中放空行!对不起.... 谢谢罗伯特,我在包含文件中有一个 db 类查询。所以,我最终所做的只是在 cURL 函数强制它重新连接之后包含它。到目前为止,这似乎是诀窍!再次感谢您的所有帮助

以上是关于间歇性 MySQL 服务器已消失错误的主要内容,如果未能解决你的问题,请参考以下文章

解决“MySQL 服务器已消失”错误

安装迁移期间mysql服务器已消失错误(laravel)

MySQL导入导致“服务器已消失”错误[重复]

SQLAlchemy 错误 MySQL 服务器已消失

错误 2006 (HY000): MySQL 服务器已消失

PHP站点中突然出现“MySQL服务器已消失”错误