php-fpm定位慢脚本
所谓的光辉岁月,并不是以后,闪耀的日子,而是无人问津时,你对梦想的偏执。
说明
PHP-FPM 提供一个叫 慢日志 (slowlog) 的功能,来帮助我们定位执行慢的脚本。
开启
以 PHP 7.2 为例,FPM 的配置信息位于:
1 | /etc/php/7.2/fpm/pool.d/www.conf |
相关配置项:
1 | ; 慢日志的存储路径,默认 `$pool` 设置为 `www` |
以上的配置翻译过来:指定 FPM 当发现有请求执行超过 1 秒钟的时候,将整个调用堆栈记录到 /var/log/www.slow.log
文件里,堆栈的深度不超过 20。
你可以把 1s 改成其他值,如 10s。有了以上的设置,裁剪图像尺寸的方法、 网络 I/O 相关的一些请求都经常出现在 PHP 慢日志中。你可以根据自己的情况来选择调整或者忽略。
如何分析?
开启了慢日志,网站运行一段时间后,如果记录了较多的慢日志,如何进行有效分析?
可以使用 grep 命令来快速定位某个函数调用、或者脚本名称被记录的次数,记录的次数越多,优化的优先级就越高。以下是简单的 示例:
1 | $ grep -o 'fetch_github_user' /var/log/www.slow.log | wc -l |
结语
慢日志可以帮助我们定位到运用程序里的瓶颈,是一个非常好用的工具,也是每个 PHP 开发者都需要知道的工具。
需要注意的是,监控 Slowlog 和记录日志的过程会对 PHP 造成消耗, 切记 调试结束后,务必将其关闭。