雖然通過nginx accesslog可以記錄用戶訪問某個接口或者網頁所消耗的時間,但是不能清晰地追蹤到具體哪個位置或者說函數慢,所以通過php-fpm慢日志,slowlog設置可以讓我們很好的看見哪些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 html' target='_blank'>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秒,會記錄這個腳本到慢日志文件中
request_slowlog_timeout =0表示關閉慢日志輸出。
慢日志文件位置默認在php的安裝目錄下的log文件夾中,可以通過修改slowlog = log/$pool.log.slow參數來指定。
; 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慢日志步驟:
cd /apps/phpvi /apps/php/etc/php-fpm.conf去掉request_slowlog_timeout 、slowlog的前綴分號 ,設置request_slowlog_timeout =1;創建慢日志目錄mkdir -p /apps/php/etc/log重啟php-fpmkillall php-fpm/apps/php/sbin/php-fpm
相關文章推薦:
php中構造方法和析構方法的代碼實現
PHP中常用的函數以及全局變量的總結(推薦)
以上就是怎么啟用php-fpm中慢日志配置?的詳細內容,PHP教程
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。
新聞熱點
疑難解答