PHP效能調優—php-fpm中啟用慢日誌配置(用於檢測執行較慢的PHP指令碼)

suboysugar發表於2017-09-03

雖然通過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 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/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

如何聯絡我:【萬里虎】www.bravetiger.cn
【QQ】3396726884 (諮詢問題100元起,幫助解決問題500元起)
【部落格】http://www.cnblogs.com/kenshinobiy/


相關文章