php – 间歇性的MySQL服务器已经消失了

发布时间:2022-04-30 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了php – 间歇性的MySQL服务器已经消失了脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。
我一直在试图找出导致脚本间歇性错误原因.错误是: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,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是你关心的两个

脚本宝典总结

以上是脚本宝典为你收集整理的php – 间歇性的MySQL服务器已经消失了全部内容,希望文章能够帮你解决php – 间歇性的MySQL服务器已经消失了所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。