Fork me on GitHub

php-fpm定位慢脚本


所谓的光辉岁月,并不是以后,闪耀的日子,而是无人问津时,你对梦想的偏执。

说明

PHP-FPM 提供一个叫 慢日志 (slowlog) 的功能,来帮助我们定位执行慢的脚本。

开启

以 PHP 7.2 为例,FPM 的配置信息位于:

1
/etc/php/7.2/fpm/pool.d/www.conf

相关配置项:

1
2
3
4
5
6
7
8
; 慢日志的存储路径,默认 `$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 命令来快速定位某个函数调用、或者脚本名称被记录的次数,记录的次数越多,优化的优先级就越高。以下是简单的 示例:

1
2
3
4
$ grep -o 'fetch_github_user' /var/log/www.slow.log | wc -l
56
$ grep -o 'sendEmail' /var/log/www.slow.log | wc -l
48

结语

慢日志可以帮助我们定位到运用程序里的瓶颈,是一个非常好用的工具,也是每个 PHP 开发者都需要知道的工具。
需要注意的是,监控 Slowlog 和记录日志的过程会对 PHP 造成消耗, 切记 调试结束后,务必将其关闭。

请我喝一个苹果味的美年达吧,谢谢!