ホームページ >バックエンド開発 >PHPチュートリアル >このコードでは常に 2 分程度で 504 プロキシ タイムアウト エラーが発生します。なぜですか?
このコードでは、$fucknum が 1000 など比較的大きい場合、504 プロキシ タイムアウト エラーが発生し、プログラムはエラーが報告された後、停止したかのように実行を継続しません。このエラーは発生しません。 $fucknum の値が比較的小さいのですが、その理由は何ですか?アドバイスをお願いします
function autonewnewegg($arr){ $fucknum=intval($arr['fucknum']); // # 获取抓取条数的整数值 $outime=$fucknum*2+100; set_time_limit($outime);//设置脚本执行时间 $nextnum=20;//连续查找10次不存在则终止 $sn=$arr['sn']; $acl=explode("-",$sn); $acl_1=preg_replace('/[^0-9]+/','',$acl[1]); //二次 $a=$b=0; //二次 while($fucknum>0){ $arr1 = $arr2 = array(); if($acl[2]<1000&&$acl_1<100){ $acl[2]=str_pad("$acl[2]",3,'0',STR_PAD_LEFT); $acl_1=str_pad("$acl_1",2,'0',STR_PAD_LEFT); $acl[1]="c".$acl_1; $arr_in=implode("-",$acl); $url=$GLOBALS['competitor'][1]['product'].$arr_in.'.htm'; if($acl[2]==999){ $acl_1=$acl_1+1; $acl[2]=001; }else { ++$acl[2]; } }elseif($acl[0]<=99){ $acl[0]=str_pad("$acl[0]",2,'0',STR_PAD_LEFT); $arr_in=implode("-",$acl); $acl[2]=001; $acl_1=01; ++$acl[0]; $url=$GLOBALS['competitor'][1]['product'].$arr_in.'.htm'; } $str = file_get_contents($url); if(!$str){ $fucknum--; }else{ $preg ='/href="http:\/\/www\.newegg\.com\.cn\/SubCategory\/(\d*)\.htm">/'; $preg2 ='/<h1>(.*)<\/h1>/'; $str = iconv("gbk","UTF-8",$str); preg_match($preg,$str,$arr1); preg_match($preg2,$str,$arr2); if(empty($arr1) || empty($arr2)){ $fucknum--; }else{ $price = $this->ocr_newegg($url); if ($price == false||$price=='.'){ $price = $this->ocr_newegg1($url); } if($price == false){ }else{ $autoarr=array('cid'=>$arr1[1],'name_newegg'=>$arr2[1],'price_newegg'=>$price,'sn_newegg'=>$arr_in); $this->addnew_newegg($autoarr); } $fucknum--; } } } return true; }
タイムアウトしたらどうすることもできません。
set_time_limit(0);
?
スクリプトがタイムアウトしないようにします: set_time_limit(0);
タイムアウトになった場合は、何もできません。
set_time_limit(0);
$outtime は $fucknum に基づいて動的に変更されます。
set_time_limit($outtime);// スクリプトの実行時間を設定します。
スクリプトをタイムアウトしないようにします: set_time_limit(0); 設定されていても、これが原因ではありません
レポートの理由は、おそらく 504 プロキシ タイムアウトです
は、クライアントからのアクセス要求を内部ネットワーク カードから受信し、同時に宛先 Web サイト サーバーに即座に転送されましたが、宛先 Web サイト サーバーは時間内に応答しませんでした。 3 秒後に 1 回再送信し、6 秒後に再度送信します。応答が受信されないため、ネットワーク カードはクライアントの HTTP/1.1 504 プロキシ タイムアウトに戻る必要があります。
レポートの理由: 504 Proxy Timeout はおそらく
5 階の heyc1998 からの返信を引用:
報告の理由: 504 Proxy Timeout が考えられます
外部ネットワーク カードは、内部ネットワーク カードからクライアントからのアクセス要求を受信した後、すぐに宛先に転送します。同時に Web サイト サーバーにアクセスしましたが、宛先 Web サイト サーバーが時間内に応答しませんでした。 3 秒後に 1 回再送信し、6 秒後に再度送信します。応答が受信されないため、ネットワーク カードはクライアントの HTTP/1.1 504 プロキシ タイムアウトに戻る必要があります。
file_get_con を使用する必要がありますか...
この現象がまだ発生するかどうかを確認するために、各ループの後に長めにスリープすることができます。 ~ リモート サーバーに問題があるはずです
6 日の helloqhq の返信からの引用フロア:
5 階の heyc1998 からの返信の引用:
報告の理由: 504 プロキシ タイムアウトはおそらく
外部ネットワーク カードは、内部ネットワーク カードからクライアントからのアクセス要求を受信した後、すぐにそれを宛先 Web サイト サーバーに同時に応答しましたが、宛先 Web サイト サーバーは時間内に応答しませんでした。 3 秒後に 1 回再送信し、6 秒後に再度送信します。応答が受信されないため、ネットワーク カードはクライアント HTTP/1.1 504 プロキシ タイムアウト エラーを報告した後にループを続行する必要があります。実行は続行されますが、エラーを報告した後にプログラムに問題が発生しているようです。while ループを終了できず、true を返しません。
6 階の helloqhq からの返信の引用:
5 階の heyc1998 からの返信の引用:
報告の理由: 504 プロキシ タイムアウトは、おそらく
外部ネットワーク カードがクライアントからのアクセス要求を受信した後です。内部ネットワーク カードは同時に、宛先 Web サイト サーバーに即座に転送されましたが、宛先 Web サイト サーバーは時間内に応答しませんでした。 3 秒後に 1 回再送信し、6 秒後に再度送信します。応答が受信されないため、ネットワーク カードはクライアントに HTTP/1.1 504 Proxy Ti... つまり、このエラーには戻り値が返されます。この戻り値はブロックされますか?
6 階の helloqhq からの返信の引用:
5 階の heyc1998 からの返信の引用:
報告の理由: 504 プロキシ タイムアウトは、おそらく
外部ネットワーク カードがクライアントからのアクセス要求を受信した後です。内部ネットワーク カードは同時に、宛先 Web サイト サーバーに即座に転送されましたが、宛先 Web サイト サーバーは時間内に応答しませんでした。 3 秒後に 1 回再送信し、6 秒後に再度再送信します。応答が受信されないため、内部ネットワーク カードはクライアント HTTP/1.1 504 プロキシ ティに戻る必要があります。2 つのデッド投稿があります。お気軽に返信してください。ポイントを付与します。
http://topic.csdn.net/u/20101128/19/0fedb777-1901-4460-945b-ddc2a8787ba0.html
http://topic.csdn.net/u/20101209/17/438c616b- 3132-41bc -a329-86f84e46a72c.html
バックエンドが終了する前にフロント デスクがタイムアウトします