PHP性能调优---php-fpm中启用慢日志配置(用于检测执行较慢的PHP脚本)
雖然通過nginx accesslog可以記錄用戶訪問某個接口或者網(wǎng)頁所消耗的時間,但是不能清晰地追蹤到具體哪個位置或者說函數(shù)慢,所以通過php-fpm慢日志,slowlog設(shè)置可以讓我們很好的看見哪些php進(jìn)程速度太慢而導(dǎo)致的網(wǎng)站問題
php-fpm.conf的配置文件中有一個參數(shù)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當(dāng)request_slowlog_timeout 設(shè)為一個具體秒時request_slowlog_timeout =1,表示如果哪個腳本執(zhí)行時間大于1秒,會記錄這個腳本到慢日志文件中
request_slowlog_timeout =0表示關(guān)閉慢日志輸出。
慢日志文件位置默認(rèn)在php的安裝目錄下的log文件夾中,可以通過修改slowlog = log/$pool.log.slow參數(shù)來指定。
; The log file for slow requests ; Default Value: not set ; Note: slowlog is mandatory if request_slowlog_timeout is set ; slowlog = log/$pool.log.slowphp-fpm慢日志的例子,慢日志會記錄下進(jìn)程號,腳本名稱,具體哪個文件哪行代碼的哪個函數(shù)執(zhí)行時間過長。
[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), loggingrequest_slowlog_timeout 和 slowlog需要同時設(shè)置,開啟request_slowlog_timeout的同時需要開啟 slowlog,慢日志路徑需要手動創(chuàng)建
具體開啟php-fpm慢日志步驟:
cd /apps/phpvi /apps/php/etc/php-fpm.conf 去掉request_slowlog_timeout 、slowlog的前綴分號';',設(shè)置request_slowlog_timeout =1; :wq 保存退出 創(chuàng)建慢日志目錄 mkdir -p /apps/php/etc/log 重啟php-fpm killall php-fpm /apps/php/sbin/php-fpm 如何聯(lián)系我:【萬里虎】www.bravetiger.cn 【QQ】3396726884 (咨詢問題100元起,幫助解決問題500元起) 【博客】http://www.cnblogs.com/kenshinobiy/總結(jié)
以上是生活随笔為你收集整理的PHP性能调优---php-fpm中启用慢日志配置(用于检测执行较慢的PHP脚本)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: python+xlrd+xlwt操作ex
- 下一篇: php使用curl下载指定大小的文件