天天看點

nginx php-fpm中啟用慢日志配置(用于檢測執行較慢的PHP腳本)

很多站長轉到nginx+php-fpm後,飽受500,502問題困擾。當nginx收到如上錯誤碼時,可以确定後端php-fpm解析php出了某種問題,比如,執行錯誤,執行逾時。

php-fpm.conf的配置檔案中有一個參數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,表示如果哪個腳本執行時間大于5秒,會記錄這個腳本到慢日志檔案中

request_slowlog_timeout =0表示關閉慢日志輸出。

慢日志檔案位置預設在php的安裝目錄下的log檔案夾中,可以通過修改slowlog = log/$pool.log.slow參數來指定。

php-fpm慢日志的例子,慢日志會記錄下程序号,腳本名稱,具體哪個檔案哪行代碼的哪個函數執行時間過長。

[21-Nov-2013 14:30:38] [pool www] pid 11877

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)

慢日志路徑需要手動建立

具體開啟php-fpm慢日志步驟:

cd /usr/local/lnmp/php

vi etc/php-fpm.conf

去掉request_slowlog_timeout 、slowlog的字首分号';',設定request_slowlog_timeout =5;

:wq

儲存退出

建立慢日志目錄

mkdir log

重新開機php-fpm

kill -INT `cat var/run/php-fpm.pid

sbin/php-fpm

     本文轉自wsw26 51CTO部落格,原文連結:http://blog.51cto.com/wsw26/1769366,如需轉載請自行聯系原作者

下一篇: memcached筆記