php-fpm中啓用慢日誌配置(用於檢測執行較慢的PHP腳本)

雖然經過nginx accesslog能夠記錄用戶訪問某個接口或者網頁所消耗的時間,可是不能清晰地追蹤到具體哪一個位置或者說函數慢,因此經過php-fpm慢日誌,slowlog設置能夠讓咱們很好的看見哪些php進程速度太慢而致使的網站問題php

php-fpm.conf的配置文件中有一個參數request_slowlog_timeout是這樣描述的nginx

; 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 =1,表示若是哪一個腳本執行時間大於1秒,會記錄這個腳本到慢日誌文件中web

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

慢日誌文件位置默認在php的安裝目錄下的log文件夾中,能夠經過修改slowlog = log/$pool.log.slow參數來指定。webapp

; The log file for slow requests
; Default Value: not set
; Note: slowlog is mandatory if request_slowlog_timeout is set
; slowlog = log/$pool.log.slow

php-fpm慢日誌的例子,慢日誌會記錄下進程號,腳本名稱,具體哪一個文件哪行代碼的哪一個函數執行時間過長。函數

[27-May-2016 13:20:37] NOTICE: child 16683 stopped for tracing
[27-May-2016 13:20:37] NOTICE: about to trace 16683
[27-May-2016 13:20:37] NOTICE: finished trace of 16683
[27-May-2016 13:20:37] WARNING: [pool www] child 16720, script '/Data/webapps/test/public/index.php' (request: "POST /index.php/test/test/") executing too slow (1.204894 sec), logging

request_slowlog_timeout 和 slowlog須要同時設置,開啓request_slowlog_timeout的同時須要開啓 slowlog,慢日誌路徑須要手動建立php-fpm

具體開啓php-fpm慢日誌步驟:網站

cd /apps/php

vi /apps/php/etc/php-fpm.conf
去掉request_slowlog_timeout 、slowlog的前綴分號';',設置request_slowlog_timeout =1;
:wq
保存退出
建立慢日誌目錄
mkdir -p /apps/php/etc/log
重啓php-fpm
killall php-fpm
/apps/php/sbin/php-fpm
相關文章
相關標籤/搜索