我一直在绞尽脑汁试图找出导致脚本间歇性错误的原因。错误是: SQLSTATE[HY000]:一般错误:2006 MySQL 服务器已经消失。
下面的脚本是一个函数的一部分,该函数执行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");
发生这种情况可能是因为您的 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是你关心的两个
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)