您的位置:首页 >Ubuntu PHP日志中的慢查询怎么办
发布于2026-04-21 阅读(0)
扫一扫,手机访问

处理PHP应用性能问题,慢查询往往是头号“嫌犯”。但慢查询这事儿,其实有两副面孔,搞混了就容易白忙活一场。
在PHP的语境里,“慢查询”通常指向两个不同层面的日志,它们分工明确:
所以,一个完整的排查链路通常是:先用PHP-FPM慢日志锁定是哪个请求、哪个环节慢了;如果问题指向数据库,再深入数据库慢日志,用EXPLAIN等工具揪出具体的SQL和索引症结。二者相辅相成,缺一不可。
要让PHP-FPM开口“说话”,首先得打开它的慢日志开关。
/etc/php/8.1/fpm/pool.d/www.conf。关键配置有两项:
slowlog = /var/log/php-fpm/www-slow.log (指定日志路径)request_slowlog_timeout = 1s (定义“慢”的阈值,比如1秒)这里有个细节:只要request_slowlog_timeout设为非0值,slowlog就必须配置。阈值可以根据业务容忍度灵活调整,0.5秒、1秒或2秒都行。
sudo mkdir -p /var/log/php-fpmsudo chown www-data:www-data /var/log/php-fpmsudo systemctl restart php8.1-fpm 让配置生效。首行会标明时间、进程池和脚本路径,例如 script_filename = /var/www/html/index.php。
接下来的多行就是宝贵的调用栈(stack trace),它会精确地告诉你,时间卡在了哪个函数、哪个文件的哪一行。比如,一行记录显示 session_start() /var/www/html/app/models/User.php:11,那优化重点就很明确了——要么优化这个session_start调用,要么检查User.php第11行附近的逻辑。根据这些热点,优先考虑引入缓存、延迟加载或重构代码。
当矛头指向数据库,就该数据库慢查询日志登场了。以MySQL 5.7及以上版本为例。
SET GLOBAL slow_query_log = ON;SET GLOBAL long_query_time = 1; (单位秒)/etc/mysql/mysql.conf.d/mysqld.cnf),在[mysqld]段落下添加:
slow_query_log = 1slow_query_log_file = /var/log/mysql/slow.loglong_query_time = 1log_queries_not_using_indexes = 1 (可选,但非常有用,能记录未使用索引的查询)配置完成后,别忘了重启MySQL服务:sudo systemctl restart mysql。
mysqldumpslow可以快速进行初步分析,例如:
mysqldumpslow -s at -t 10 /var/log/mysql/slow.log (按平均查询时间排序,取出最慢的10条)pt-query-digest可以生成一份详细的报告:
sudo apt-get install percona-toolkitpt-query-digest /var/log/mysql/slow.log > slow_report.txt这份报告会帮你统计出哪些SQL最耗时、执行频率最高,并给出优化建议样本。
EXPLAIN命令查看其执行计划。重点关注:
type列:如果出现ALL,意味着全表扫描,这是重大警报。key列:如果为NULL,说明查询没有使用索引。rows列:预估扫描的行数,数值过大就需要警惕。根据EXPLAIN的结果,有针对性地添加或修改索引、重写SQL语句。
定位问题只是第一步,接下来才是重头戏——优化。这里有一份从数据库到PHP的立体优化清单。
WHERE、JOIN、ORDER BY、GROUP BY子句中的列建立合适的索引。SELECT *,只查询需要的字段。WHERE条件中对列使用函数(这会导致索引失效)。LIMIT。pm = dynamicpm.max_children = 50pm.start_servers = 5pm.min_spare_servers = 5pm.max_spare_servers = 35request_terminate_timeout = 30s (这个值应与你的业务超时策略保持一致)[opcache]opcache.enable=1opcache.memory_consumption=128opcache.interned_strings_buffer=8opcache.max_accelerated_files=4000最后,送你一份可以贴在墙上的快速行动清单,遇到性能问题时按图索骥:
pt-query-digest或mysqldumpslow找出最耗时的Top N条SQL。EXPLAIN检查其执行计划,重点关注扫描类型和行数。
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9