【发布时间】: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 还是新手,会解决这个问题!谢谢指出