php – 间歇性的MySQL服务器已经消失了
发布时间:2020-12-13 17:13:03 所属栏目:PHP教程 来源:网络整理
导读:我一直在试图找出导致脚本间歇性错误的原因.错误是:SQLSTATE [HY000]:一般错误:2006 MySQL服务器已经消失. 我的下面的脚本是一个函数的一部分,它执行curl,从JSON响应中获取一些值,然后将它们写入表中.我说80%的时间它工作正常,然后另外20%我得到服务器
我一直在试图找出导致脚本间歇性错误的原因.错误是: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连接超时花费的时间更长
或 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是你关心的两个 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |