4

スクリプトで断続的なエラーが発生している原因を突き止めようと頭を悩ませてきました。エラーは次のとおりです。SQLSTATE[HY000]:一般的なエラー:2006MySQLサーバーがなくなりました。

以下の私のスクリプトは、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");
4

1 に答える 1

4

これは、CURLリクエストがmysql接続タイムアウトよりも長くかかっているために発生している可能性があります

1)CURLのrequest-timeoutを設定して、エラーが発生するとすぐに終了するようにします(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はあなたが気にする2つです

于 2012-08-27T22:44:53.727 に答える