PHP效能調優—php-fpm中啟用慢日誌配置(用於檢測執行較慢的PHP指令碼)
雖然通過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/
相關文章
- nginxphp-fpm中啟用慢日誌配置(用於檢測執行較慢的PHP指令碼)NginxPHP指令碼
- 開啟php-fpm慢指令碼日誌PHP指令碼
- php-fpm慢執行日誌PHP
- php-fpm的pool、php-fpm慢執行日誌、open_basedir、php-fpm程式管理PHP
- PHP慢指令碼日誌和Mysql的慢查詢日誌PHP指令碼MySql
- php-fpm的pool、慢執行日誌、程式管理、open_basedirPHP
- PHP-FPM 導致負載過高的排查方法 善用PHP慢執行日誌slow logPHP負載
- 開啟mysql和php慢日誌方法MySqlPHP
- 用於對執行慢的查詢進行優化優化
- dg庫日誌應用慢引數調整
- mysql開啟檢視慢查詢日誌MySql
- MySQL慢日誌優化MySql優化
- 【PHP】啟用php-fpm狀態詳解PHP
- mysql開啟慢日誌MySql
- MySQL 每天自行統計慢日誌 指令碼MySql指令碼
- mysql5.7 慢日誌配置MySql
- 如何啟用Hibernate慢查詢日誌? -Vlad Mihalcea
- PHP5.6中php-fpm的配置、啟動、關閉和重啟PHP
- php-fpm的配置和優化PHP優化
- 如何啟用 Apache 的 PHP-FPM 多例項ApachePHP
- php效能調優PHP
- 12.21php-fpm的pool12.22php-fpm慢執行日誌12.23open_basedir12.24php-fpm程式管理PHP
- 如何在MySQL中開啟慢查詢日誌?MySql
- PHP多程式並行執行php指令碼PHP並行指令碼
- 慢查詢日誌開啟分析
- redis慢日誌Redis
- 用SeasLog打造PHP高效能日誌元件PHP元件
- 記一次 PHP-FPM 可以建立慢日誌,但是卻不能寫入內容的折騰過程PHP
- 用於對執行慢的查詢進行分析的清單
- mysql 鎖的慢日誌MySql
- 線上定時指令碼執行慢,分析過程指令碼
- 2.4慢操作日誌
- PHP-FPM 的三種執行模式PHP模式
- MYSQL啟用日誌和檢視日誌MySql
- MySQLSlowlog慢查詢日誌的配置以及清空日誌內容MySql
- Mysql 啟動慢查詢日誌 (不用重啟)MySql
- 通過spid,查詢執行慢的sql指令碼SQL指令碼
- PHP 應用效能優化指南PHP優化