1. 程式人生 > >php-fpm中啟用慢日誌配置以檢測執行較慢的PHP指令碼

php-fpm中啟用慢日誌配置以檢測執行較慢的PHP指令碼

php-fpm慢日誌slowlog設定可以讓開發者很好的查詢哪些php程序速度過慢而導致的網站問題,讓開發者方便的找到問題的所在。該方法同樣適用於排查nginx的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/nginx/html/www.quancha.cn/www/fyzb.php

[0xb70fb88c] file_get_contents() /usr/local/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/php/log/www.log.slow): No such file or directory (2)

慢日誌路徑需要手動建立,具體開啟php-fpm慢日誌步驟:

  1. cd /usr/local/php
  2. vi etc/php-fpm.conf
  3. 去掉request_slowlog_timeout slowlog的字首分號';',設定request_slowlog_timeout =5
  4. :wq
  5. 儲存退出
  6. 建立慢日誌目錄
  7. mkdir log
  8. 重啟php-fpm
  9. kill -INT `cat var/run/php-fpm.pid
  10. sbin/php-fpm