校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > php-fpm超時時間設置request_terminate_timeout資源問題分析

php-fpm超時時間設置request_terminate_timeout資源問題分析

熱門標簽:AI電話機器人OEM貼牌 銅川電話機器人價格 江蘇電商外呼系統運營商 沛縣400電話辦理 青白江地圖標注 德陽中江如何申請400開頭電話 聊城電話外呼系統公司 辦理重慶400電話 智能電話機器人好公司門薩維

php日志中有一條超時的日志,但是我request_terminate_timeout中設置的是0,理論上應該沒有超時時間才對。

PHP Fatal error: Maximum execution time of 30 seconds exceeded in ...

OK,先列出現在的配置:

php-fpm:
request_terminate_timeout = 0
php.ini:
max_execution_time = 30

先查閱了一下php-fpm文件中關于request_terminate_timeout的注釋

; The timeout for serving a single request after which the worker process will
; be killed. This option should be used when the 'max_execution_time' ini option
; does not stop script execution for some reason. A value of '0' means 'off'.
; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
; Default Value: 0

這個注釋說明了,request_terminate_timeout 適用于,當max_execution_time由于某種原因無法終止腳本的時候,會把這個php-fpm請求干掉。

再看看max_execution_time的注釋:這設置了腳本被解析器中止之前允許的最大執行時間,默認是30s。看樣子,我這個請求應該是被max_execution_time這個設置干掉了。

好吧,不死心,做了一個實驗:

php-fpm request_terminate_timeout 設置 0 15
php.ini max_execution_time 設置 30 30
執行結果 php有Fatal error超時日志,http狀態碼為500 php無Fatal error超時日志,http狀態碼為502,php-fpm日志中有殺掉子進程日志

好吧,結論是web請求php執行時間受到2方面控制,一個是php.ini的max_execution_time(要注意的是sleep,http請求等待響應的時間是不算的,這里算的是真正的執行時間),另一個是php-fpm request_terminate_timeout 設置,這個算的是請求開始n秒。

request_terminate_timeout引起的資源問題

request_terminate_timeout的值如果設置為0或者過長的時間,可能會引起file_get_contents的資源問題。
如果file_get_contents請求的遠程資源如果反應過慢,file_get_contents就會一直卡在那里不會超時。我們知道php.ini 里面max_execution_time 可以設置 PHP 腳本的最大執行時間,但是,在 php-cgi(php-fpm) 中,該參數不會起效。

真正能夠控制 PHP 腳本最大執行時間的是 php-fpm.conf 配置文件中的request_terminate_timeout參數。
request_terminate_timeout默認值為 0 秒,也就是說,PHP 腳本會一直執行下去。
這樣,當所有的 php-cgi 進程都卡在 file_get_contents() 函數時,這臺 Nginx+PHP 的 WebServer 已經無法再處理新的 PHP 請求了,

Nginx 將給用戶返回“502 Bad Gateway”。修改該參數,設置一個 PHP 腳本最大執行時間是必要的,
但是,治標不治本。例如改成 30s,如果發生 file_get_contents() 獲取網頁內容較慢的情況,這就意味著 150 個 php-cgi 進程,每秒鐘只能處理 5 個請求,WebServer 同樣很難避免”502 Bad Gateway”。

解決辦法是:request_terminate_timeout設置為10s或者一個合理的值,
或者給file_get_contents加一個超時參數。

$ctx = stream_context_create(array(
  'http' => array(
    'timeout' => 10  //設置一個超時時間,單位為秒
  )
));
 
file_get_contents($str, 0, $ctx);

php-fpm中的request_terminate_timeout最好不要設置

剛轉到php-fpm沒幾天就發現,進入我的joomla后臺,firefox偶爾會給我白屏的那種http 503,這種情況僅出現在天翼云的服務器上,而我在國外的同樣配置的服務器一點問題都沒有,后來發現是request_terminate_timeout的問題。

每次登陸joomla后臺,joomla都會去檢查是否有更新(檢查成功后cache,默認保存該cache 6小時),而且分為joomla主程序和joomla擴展兩個部分,如下圖:

不出意外的話,服務器會發起兩個php進程,分別分配給兩個php-fpm children,去連接joomla的官方update服務器。好,問題就來了,我的request_terminate_timeout = 30s,30秒不完成則超時,參見天翼云主機的國際出口相當蛋疼!沒錯,30秒內,天翼云主機根本無法完成連接joomla更新服務器并檢查是否有更新這整個過程。這也很好解釋了為什么同樣配置的國外服務器就沒有問題,因為它們完成上述更細過程僅需要在2~5秒左右。

我的apache超時設置是30秒,php.ini中最長執行時間野是30秒,多年來都沒有任何問題,沒有30秒還打不開的網頁,所以我就沒多想給php-fpm的request_terminate_timeout = 30s。經過這次的事情發現此30秒非鄙30秒啊……

php-fpm設置request_terminate_timeout后,php.ini中的max_execution_time和max_input_time都會失效,以php-fpm中的設置為準;
apache+mod_php在timeout后,只會在日志中記錄一下,僅此而已。php-fpm中的request_terminate_timeout超時之后,日志中記錄http 503的同時,最要命的,它還會直接殺死造成這個http 503的php-fpm child,并生成新的child。
在我的joomla更新這個實例中,就會有兩個php-fpm children同時被殺死。而我的天翼云主機是低配,只有一個cpu核心,我也只啟動了兩個php-fpm children,兩個同時死了,我的firefox這邊也就http 503 Service Unavailable的白屏了。php-fpm的error_log如下:

[27-Sep-2014 10:41:06] WARNING: [pool www] child 1882, script '/home/onepx/public_html/administrator/index.php' (request: "POST /administrator/index.php") execution timed out (30.004534 sec), terminating
[27-Sep-2014 10:41:06] WARNING: [pool www] child 1882 exited on signal 15 (SIGTERM) after 164.717323 seconds from start

[27-Sep-2014 10:41:06] NOTICE: [pool www] child 1886 started
[27-Sep-2014 10:41:06] WARNING: [pool www] child 1883, script '/home/onepx/public_html/administrator/index.php' (request: "POST /administrator/index.php") execution timed out (30.005201 sec), terminating
[27-Sep-2014 10:41:06] WARNING: [pool www] child 1883 exited on signal 15 (SIGTERM) after 166.718162 seconds from start
[27-Sep-2014 10:41:06] NOTICE: [pool www] child 1887 started

像joomla這種全php的網站,每個連接都需要apache+php-fpm協同運作。即便php-fpm中的request_terminate_timeout時間設置很長,apache中的timeout時間設置略短,只要apache的timeout到了,php-fpm照樣在后面殺進程……
如果網站的訪問者比較多,php-fpm的child是被許多訪問者共用的,殺一個child,就有可能導致幾個用戶同時http 503 Service Unavailable。所以,我的建議是——php-fpm中的request_terminate_timeout最好不要設置,只給apache一個timeout就夠了。

標簽:赤峰 鷹潭 烏魯木齊 山南 南寧 濟寧 迪慶 三亞

巨人網絡通訊聲明:本文標題《php-fpm超時時間設置request_terminate_timeout資源問題分析》,本文關鍵詞  php-fpm,超時,時間,設置,request,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《php-fpm超時時間設置request_terminate_timeout資源問題分析》相關的同類信息!
  • 本頁收集關于php-fpm超時時間設置request_terminate_timeout資源問題分析的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    狠狠色丁香久久婷婷综合丁香| 亚洲444eee在线观看| 777午夜精品免费视频| 色婷婷综合久久久中文字幕| av在线综合网| 91日韩在线专区| 在线这里只有精品| 欧美日韩成人在线一区| 欧美日本一区二区在线观看| 欧美日韩视频在线观看一区二区三区| 色中色一区二区| 欧美日韩电影在线| 日韩一级完整毛片| 久久久久久久久伊人| 中文字幕一区二区三区色视频| 国产精品久久久久精k8| 亚洲久草在线视频| 奇米精品一区二区三区四区 | 一本一道综合狠狠老| 91视频一区二区| 欧美羞羞免费网站| 日韩欧美国产午夜精品| 国产欧美一二三区| 亚洲伦在线观看| 日韩精品每日更新| 国产伦精品一区二区三区视频青涩| 大尺度一区二区| 欧美日韩精品一二三区| 欧美精品一区二区精品网| 国产女同互慰高潮91漫画| 亚洲欧美激情一区二区| 日韩电影在线观看一区| 国产成人在线观看| 欧美午夜电影一区| 久久久99精品免费观看不卡| 亚洲码国产岛国毛片在线| 蜜臀av国产精品久久久久 | 色国产精品一区在线观看| 欧美裸体bbwbbwbbw| 久久精品水蜜桃av综合天堂| 亚洲另类一区二区| 国产一区二区福利| 欧美巨大另类极品videosbest| 欧美精品一区二区三区在线 | 成人免费在线播放视频| 三级欧美韩日大片在线看| 成人在线视频一区二区| 欧美一区二区黄色| 亚洲精品久久7777| 岛国一区二区三区| 日韩一二在线观看| 亚洲综合在线电影| 成人做爰69片免费看网站| 日韩欧美精品在线| 日日摸夜夜添夜夜添精品视频| 99视频一区二区三区| 久久久综合精品| 欧美aa在线视频| 777欧美精品| 午夜电影一区二区三区| 日本韩国欧美一区二区三区| 中文字幕一区免费在线观看| 国产在线精品视频| 日韩精品一区二| 美女网站一区二区| 91精品综合久久久久久| 亚洲视频 欧洲视频| 成人午夜在线视频| 中文字幕在线播放不卡一区| 成人性色生活片免费看爆迷你毛片| 久久色在线观看| 国产精品白丝jk白祙喷水网站| 欧美mv日韩mv国产网站| 日本不卡视频在线| 欧美成人一区二区三区在线观看| 日本亚洲天堂网| 欧美精品一区二区三区很污很色的| 青青国产91久久久久久| 制服视频三区第一页精品| 日韩精品一二三四| 日韩一区二区三区电影| 午夜成人在线视频| 欧美大白屁股肥臀xxxxxx| 蜜臀av一区二区三区| 欧美成人一区二区| 成人夜色视频网站在线观看| 中文av一区二区| 91麻豆国产自产在线观看| 亚洲精品成人少妇| 欧美年轻男男videosbes| 日韩av在线免费观看不卡| 日韩欧美色综合| 国产成人免费在线观看不卡| 国产精品视频在线看| 在线亚洲一区观看| 美女视频一区二区三区| 久久久久久久久久美女| 成人免费福利片| 亚洲成人一二三| 精品免费视频.| 99久久99久久免费精品蜜臀| 亚洲国产aⅴ成人精品无吗| 欧美一区二区精品久久911| 国产精品一二三四区| 亚洲欧美日韩在线播放| 日韩欧美在线1卡| 成人精品在线视频观看| 亚洲一区二区三区精品在线| 精品久久久久av影院| 91尤物视频在线观看| 日韩电影在线观看电影| 国产精品天美传媒| 欧美精品久久久久久久多人混战 | 麻豆成人久久精品二区三区红| 久久久久久久综合日本| 欧美日韩不卡一区| 成人综合激情网| 免费成人美女在线观看| 亚洲人成精品久久久久久| 精品国产乱码久久久久久影片| 一本久久综合亚洲鲁鲁五月天 | ww亚洲ww在线观看国产| 色婷婷亚洲一区二区三区| 国产一区视频在线看| 亚洲制服丝袜av| 中文幕一区二区三区久久蜜桃| 51精品国自产在线| 91久久一区二区| 波多野结衣中文一区| 蓝色福利精品导航| 香港成人在线视频| 国产精品国模大尺度视频| 26uuu精品一区二区在线观看| 在线不卡中文字幕| 欧美三级乱人伦电影| 99在线热播精品免费| 国产成人精品综合在线观看| 日韩精品电影在线观看| 一区二区三国产精华液| 1024国产精品| 亚洲天堂av一区| 中文字幕国产一区| 中文字幕免费在线观看视频一区| 日韩美女在线视频| 欧美一级免费大片| 欧美精品少妇一区二区三区| 欧美午夜电影在线播放| 欧美无人高清视频在线观看| 色婷婷久久久综合中文字幕 | 五月天激情小说综合| 亚洲精品伦理在线| 亚洲男同1069视频| 一区二区欧美精品| 亚洲第四色夜色| 视频在线在亚洲| 日本中文在线一区| 久久99久久99小草精品免视看| 麻豆视频观看网址久久| 久久国产麻豆精品| 国产在线乱码一区二区三区| 色婷婷综合久久| 在线一区二区视频| 3d动漫精品啪啪1区2区免费 | 精品一区二区三区的国产在线播放 | 欧美精品欧美精品系列| 91精品在线免费| 久久一二三国产| 国产亚洲精久久久久久| 国产精品福利电影一区二区三区四区| 欧美国产成人在线| 一区二区三区中文在线| 亚洲妇熟xx妇色黄| 久久精品理论片| 99r精品视频| 欧美日韩电影一区| 国产欧美日韩激情| 一区二区三区国产| 激情五月播播久久久精品| 国产成a人亚洲精品| 色999日韩国产欧美一区二区| 欧美日韩成人综合在线一区二区| 日韩欧美色综合网站| 国产精品电影一区二区| 五月婷婷久久综合| 大尺度一区二区| 欧美一级xxx| 中文字幕在线播放不卡一区| 三级久久三级久久久| 成人免费精品视频| 欧美精选一区二区| 国产欧美一区二区精品仙草咪| 亚洲第一福利一区| youjizz久久| 欧美大片顶级少妇| 亚洲综合免费观看高清完整版在线 | 日韩精品成人一区二区在线| 国产高清精品网站| 欧美一级在线免费| 最新不卡av在线| 国产在线精品免费|