PHP-FPM卡顿主因是子进程耗尽而非代码问题,需检查active processes是否达max_children、验证OPcache是否生效、排查N+1查询及Xdebug隐性加载。

网站卡顿如何快速排查_PHP高并发性能故障排查指南【方法】

看一眼就知道是不是PHP-FPM卡住了

很多“网站卡顿”其实根本不是代码问题,而是 PHP-FPM 子进程全在排队等处理——你刷新页面要等 3 秒以上,top 里却看不到 PHP 进程占 CPU,反而 nginx 的 worker 进程大量处于 sleeping 状态,这就是典型 FPM 响应不过来。

别急着加机器——90% 的情况是某个接口死循环、没设超时的 cURL、或数据库锁表,导致一个请求卡住整个 worker。

opcache_get_status() 两秒确认字节码缓存是否真在干活

很多人以为开了 opcache.enable=1 就万事大吉,但实际中常因配置错位或缓存击穿导致 OPcache 形同虚设。最直接的验证方式不是看 phpinfo,而是调用函数实时查状态。

数据库 N+1 查询,slow_query_log 可能根本抓不到

MySQL 慢日志只记录单条 SQL 超时,但 N+1 是 100 个 20ms 的查询连发——总耗时 2 秒,每个都躲过 long_query_time=1,结果页面卡死,日志却干干净净。

别让 Xdebug 在生产环境偷偷吃掉 300% 的响应时间

很多团队说“我们没开 Xdebug”,但检查 php --ini 会发现 xdebug.so 仍被加载,只是 xdebug.mode 设成了 off——这依然会让每次请求多花 50~200ms 初始化调试器上下文。

性能排查最怕“以为修好了”,实际上只是把症状压下去了。比如调大 pm.max_children 暂时缓解排队,但那个卡住的慢查询还在——下次流量高峰它会立刻回来。真正的快,是让每个请求从进来到返回,路径清晰、无盲区、可度量。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。