nginxphp-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
相關文章
- PHP效能調優—php-fpm中啟用慢日誌配置(用於檢測執行較慢的PHP指令碼)PHP指令碼
- PHP慢指令碼日誌和Mysql的慢查詢日誌PHP指令碼MySql
- 開啟php-fpm慢指令碼日誌PHP指令碼
- php-fpm慢執行日誌PHP
- 開啟mysql和php慢日誌方法MySqlPHP
- mysql開啟檢視慢查詢日誌MySql
- mysql開啟慢日誌MySql
- MySQL 每天自行統計慢日誌 指令碼MySql指令碼
- php-fpm的pool、慢執行日誌、程式管理、open_basedirPHP
- mysql5.7 慢日誌配置MySql
- 如何啟用Hibernate慢查詢日誌? -Vlad Mihalcea
- 用於對執行慢的查詢進行優化優化
- 如何在MySQL中開啟慢查詢日誌?MySql
- 慢查詢日誌開啟分析
- redis慢日誌Redis
- php-fpm的pool、php-fpm慢執行日誌、open_basedir、php-fpm程式管理PHP
- 用於對執行慢的查詢進行分析的清單
- dg庫日誌應用慢引數調整
- mysql 鎖的慢日誌MySql
- PHP-FPM 導致負載過高的排查方法 善用PHP慢執行日誌slow logPHP負載
- 線上定時指令碼執行慢,分析過程指令碼
- 2.4慢操作日誌
- MYSQL啟用日誌和檢視日誌MySql
- MySQLSlowlog慢查詢日誌的配置以及清空日誌內容MySql
- Mysql 啟動慢查詢日誌 (不用重啟)MySql
- 通過spid,查詢執行慢的sql指令碼SQL指令碼
- MYSQL開啟慢查詢日誌實施MySql
- 慢查詢日誌的管理
- MySQL 慢查詢日誌——讓“慢”無所遁形MySql
- MySQL慢日誌全解析MySql
- MySQL:慢查詢日誌MySql
- MySQL慢日誌優化MySql優化
- 使用慢查詢日誌
- mysql慢查詢日誌MySql
- 開啟查詢慢查詢日誌引數
- 關於MySQL 通用查詢日誌和慢查詢日誌分析MySql
- MySQL資料庫中的日誌檔案---(3)慢查詢日誌MySql資料庫
- Linux下mysql配置慢日誌查詢,把查詢慢的sql記錄下來LinuxMySql