36. 开启 Slow log 定位慢脚本
说明
PHP-FPM 提供一个叫 慢日志(slowlog) 的功能,来帮助我们定位执行慢的脚本。
如何开启?
本文以 PHP 7.2 为例,FPM 的配置信息位于:
/etc/php/7.2/fpm/pool.d/www.conf
相关配置项:
; 慢日志的存储路径,默认 `$pool` 设置为 `www`
slowlog = /var/log/$pool.slow.log
; 设置慢日志超时标准,设置为 0 代表关闭慢日志
request_slowlog_timeout = 1s
; 慢日志记录脚本堆栈的深度
request_slowlog_trace_depth = 20
以上的配置翻译过来:指定 FPM 当发现有请求执行超过 1 秒钟的时候,将整个调用堆栈记录到 /var/log/www.slow.log
文件里,堆栈的深度不超过 20。
你可以把 1s 改成其他值,如 10s。有了以上的设置,裁剪图像尺寸的方法、 网络 I/O 相关的一些请求都经常出现在 PHP 慢日志中。你可以根据自己的情况来选择调整或者忽略。
如何分析?
开启了慢日志,网站运行一段时间后,如果记录了较多的慢日志,如何进行有效分析?
可以使用 grep
命...