nginx php-fpm中啟用慢日志配置(用于檢測執(zhí)行較慢的PHP腳本)
很多站長轉(zhuǎn)到nginx+php-fpm后,飽受500,502問題困擾。當nginx收到如上錯誤碼時,可以確定后端php-fpm解析php出了某種問題,比如,執(zhí)行錯誤,執(zhí)行超時。
php-fpm.conf的配置文件中有一個參數(shù)request_slowlog_timeout是這樣描述的
; The timeout for serving a single request after which a PHP backtrace will be
; dumped to the 'slowlog' file. A value of '0s' means 'off'.
; Available units: s(econds)(default), m(inutes), h(ours), or d(ays)
; Default Value: 0
;request_slowlog_timeout = 0
當request_slowlog_timeout 設為一個具體秒時request_slowlog_timeout =5,表示如果哪個腳本執(zhí)行時間大于5秒,會記錄這個腳本到慢日志文件中
request_slowlog_timeout =0表示關(guān)閉慢日志輸出。
慢日志文件位置默認在php的安裝目錄下的log文件夾中,可以通過修改slowlog = log/$pool.log.slow參數(shù)來指定。
php-fpm慢日志的例子,慢日志會記錄下進程號,腳本名稱,具體哪個文件哪行代碼的哪個函數(shù)執(zhí)行時間過長。
script_filename = /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php
[0xb70fb88c] file_get_contents() /usr/local/lnmp/nginx/html/www.quancha.cn/www/fyzb.php:2
[21-Nov-2013 14:15:23] ERROR: [pool www] 'slowlog' must be specified for use with 'request_slowlog_timeout'
request_slowlog_timeout 和 slowlog需要同時設置,開啟request_slowlog_timeout的同時需要開啟 slowlog
[21-Nov-2013 14:16:27] ERROR: Unable to create or open slowlog(/usr/local/lnmp/php/log/www.log.slow): No such file or directory (2)
慢日志路徑需要手動創(chuàng)建
具體開啟php-fpm慢日志步驟:
cd /usr/local/lnmp/php
vi etc/php-fpm.conf
去掉request_slowlog_timeout 、slowlog的前綴分號';',設置request_slowlog_timeout =5;
:wq
保存退出
創(chuàng)建慢日志目錄
mkdir log
重啟php-fpm
kill -INT `cat var/run/php-fpm.pid
sbin/php-fpm
相關(guān)文章
解決httpd占用80端口導致Nginx啟動失敗報錯的解決辦法
今天在建自己小網(wǎng)站時啟動Nginx時,發(fā)現(xiàn)其報下列錯誤,意思是因為80端口被占用導致Nginx啟動失敗,所以本文小編給大家介紹介紹如何解決解決httpd占用80端口導致Nginx啟動不成功報nginx: [emerg] bind() to 0.0.0.0:80 failed (98: Address already in use)2023-11-11nginx worker進程循環(huán)的實現(xiàn)
這篇文章主要介紹了nginx worker進程循環(huán)的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-02-02在Ubuntu系統(tǒng)上安裝Nginx服務器的簡單方法
這篇文章主要介紹了在Ubuntu系統(tǒng)上安裝Nginx服務器的簡單方法,包括打開和關(guān)閉Nginx的指令,需要的朋友可以參考下2015-08-08