色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

PHP http請(qǐng)求超時(shí)問(wèn)題解決方案

瀏覽:69日期:2022-09-08 17:06:21

一,http請(qǐng)求超時(shí)時(shí)間

可能出現(xiàn)的場(chǎng)景:

1,curl進(jìn)程運(yùn)行了一個(gè)世紀(jì)還木結(jié)束,curl的時(shí)候設(shè)置了超時(shí)時(shí)間 --connect-timeout 1000

2,operation timed out after 1000 milliseconds with 0 bytes received

3,connect() timed out!

wget對(duì)超時(shí)時(shí)間, 是有分階段的, 比如說(shuō)請(qǐng)求的超時(shí), 傳輸?shù)某瑫r(shí),同樣HTTP請(qǐng)求有兩個(gè)超時(shí)時(shí)間:一個(gè)是連接超時(shí)時(shí)間,另一個(gè)是數(shù)據(jù)傳輸?shù)淖畲笤试S時(shí)間,出現(xiàn)問(wèn)題就要看是哪個(gè)超時(shí)時(shí)間出問(wèn)題了。

curl命令行連接超時(shí)時(shí)間用 --connect-timeout 參數(shù)來(lái)指定,數(shù)據(jù)傳輸?shù)淖畲笤试S時(shí)間用 -m 參數(shù)來(lái)指定,時(shí)間是毫秒

例如:

curl --connect-timeout 10 -m 20 'http://***'

連接超時(shí)的話(huà),出錯(cuò)提示形如:

curl: (28) connect() timed out!

數(shù)據(jù)傳輸?shù)淖畲笤试S時(shí)間超時(shí)的話(huà),出錯(cuò)提示形如:

curl: (28) Operation timed out after 2000 milliseconds with 0 bytes received

使用PHP的curl_init

<?php // create a new cURL resource $ch = curl_init(); // set URL and other appropriate options curl_setopt($ch, CURLOPT_URL, 'http://www.example.com/'); curl_setopt($ch, CURLOPT_HEADER, 0);

//連接超時(shí)時(shí)間 curl_setopt($ch, CURLOPT_CONNECTTIMEOUT, 1000);

//數(shù)據(jù)傳輸?shù)淖畲笤试S時(shí)間 curl_setopt($ch, CURLOPT_TIMEOUT, 1000); // grab URL and pass it to the browser curl_exec($ch); // close cURL resource, and free up system resources curl_close($ch);

//使用curl_error($ch)查看錯(cuò)誤的詳情 var_dump(curl_error($ch));

二,頁(yè)面執(zhí)行時(shí)間

當(dāng)你的頁(yè)面有大量數(shù)據(jù)時(shí),建議使用set_time_limit()來(lái)控制運(yùn)行時(shí)間,配置該頁(yè)最久執(zhí)行時(shí)間。

設(shè)定一個(gè)程式所允許執(zhí)行的秒數(shù),如果到達(dá)限制的時(shí)間,程式將會(huì)傳回錯(cuò)誤,時(shí)間是秒單位。

php.ini:它預(yù)設(shè)的限制時(shí)間是30秒,max_execution_time的值定義在結(jié)構(gòu)檔案中,如果將秒數(shù)設(shè)為0,表示無(wú)時(shí)間上的限制,修改后重新啟動(dòng)apache/nginx服務(wù)器

php代碼:set_time_limit(800);

這個(gè)函數(shù)指定了當(dāng)前所在php腳本的最大執(zhí)行時(shí)間為800秒,實(shí)際上最大執(zhí)行時(shí)間=php.ini里的max_execution_time數(shù)值 - 當(dāng)前腳本已經(jīng)執(zhí)行的時(shí)間 + 設(shè)定值

假如php.ini里的max_execution_time=30,當(dāng)前腳本已經(jīng)執(zhí)行5秒,則:

最大執(zhí)行時(shí)間=30-5+800=825秒。

注意 : 當(dāng)PHP是執(zhí)行在安全模式時(shí),set_time_limit( )將不會(huì)有結(jié)果,除非是關(guān)閉安全模式或是修改結(jié)構(gòu)檔案中的時(shí)間限制。

三,php長(zhǎng)連接

如果我們需要一個(gè)腳本持續(xù)的運(yùn)行,那么我們就要通過(guò)php長(zhǎng)連接的方式,來(lái)達(dá)到運(yùn)行目的。通過(guò) set_time_limit 來(lái)設(shè)置一個(gè)腳本的執(zhí)行時(shí)間為無(wú)限長(zhǎng);然后使用 flush() 和 ob_flush() 來(lái)清除服務(wù)器緩沖區(qū),隨時(shí)輸出腳本的返回值。

如下面這段腳本:

<?phpheader('Content-Type: text/plain');set_time_limit(0);$infoString = 'Hello World' . 'n';while( isset($infoString) ){ echo $infoString; flush(); ob_flush(); sleep(5);}?>

當(dāng)我們執(zhí)行后,每隔5秒鐘,我們會(huì)得到一行 Hello World ,如果不按停止按鈕,瀏覽器會(huì)不停的一行一行繼續(xù)加載。

通過(guò)這一方法,我們可以完成很多功能,例如機(jī)器人爬蟲(chóng)、即時(shí)留言板等程序。

如果要停止運(yùn)行只能重啟php-fpm:

查看php-fpm進(jìn)程數(shù):

ps aux | grep -c php-fpm

查看運(yùn)行內(nèi)存

/usr/bin/php -i|grep mem

重啟php-fpm

/etc/init.d/php-fpm restart

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: PHP
相關(guān)文章:
主站蜘蛛池模板: 神马午夜-午夜片 | 亚洲人视频在线观看 | 美女又爽又黄视频 | 美女大片高清特黄a大片 | 成人午夜免费观看 | 韩国免费a级毛片 | 一级 黄 色 片免费 一级aaaaaa毛片免费 | 美女黄网站视频 | 欧美午夜成年片在线观看 | 亚洲国产精品久久久久秋霞不卡 | 看真人视频a级毛片 | 国内精品国语自产拍在线观看55 | 成人在线观看网址 | 国产日韩欧美精品一区二区三区 | 国产三级国产精品国产普男人 | 久久狠狠色狠狠色综合 | 成人免费的性色视频 | 午夜不卡视频 | 国产在线视频欧美亚综合 | 全国男人的天堂网站 | 欧美日韩精品乱国产538 | 一级做a爱 一区 | 欧美jlzz18性欧美 | 久久dj视频| 免费看亚洲 | 国产成人综合一区精品 | 中文国产成人精品久久一 | 久久99亚洲精品久久 | 久久久高清免费视频 | 黄色网址网站在线观看 | 国产欧美日韩综合精品无毒 | 日韩欧美一区二区三区不卡在线 | 国产精品毛片一区二区三区 | 在线精品欧美日韩 | 亚洲 欧美 日韩中文字幕一区二区 | 欧美成人性色区 | 毛片大片免费看 | 国产精品亚洲第一区二区三区 | 好吊操这里只有精品 | 亚州综合网 | 亚洲视频在线精品 |