SQL慢查询日志如何开启_排查性能问题第一步【教程】

2次阅读

开启 mysql 慢查询日志是排查性能问题最直接、最基础的步骤,通过设置 slow_query_log=ON、long_query_time(建议 1–3 秒)和 slow_query_log_file 路径,可捕获超时 SQL;需验证日志记录与 Slow_queries 状态是否匹配。

SQL 慢查询日志如何开启_排查性能问题第一步【教程】

开启 MySQL 慢查询日志是排查性能问题最直接、最基础的一步。它能自动捕获执行时间超过阈值的 SQL,帮你快速锁定“拖慢系统”的语句,不用靠猜或等用户反馈。

确认当前是否已开启

登录 MySQL 后执行:

  • SHOW varIABLES LIKE ‘%slow_query_log%’; —— 查看 slow_query_log 值是否为 ON
  • SHOW VARIABLES LIKE ‘long_query_time’; —— 查看当前阈值(默认 10 秒,通常需调低)
  • SHOW VARIABLES LIKE ‘%slow_query_log_file%’; —— 确认日志保存路径,如 /var/lib/mysql/xxx-slow.log

临时开启(重启不失效,适合调试)

无需改 配置文件,立即生效(但服务重启后会恢复原状):

  • SET GLOBAL slow_query_log = 1;
  • SET GLOBAL long_query_time = 2;(建议设为 1–3 秒,便于测试环境捕捉真实慢 SQL)
  • 注意:修改 long_query_time 后,** 新连接才生效 **;已有连接仍沿用旧值

永久开启(生产 / 测试环境推荐)

编辑 MySQL 配置文件/etc/my.cnf/etc/mysql/my.cnf),在 [mysqld] 区块下添加:

  • slow_query_log = 1
  • slow_query_log_file = /var/log/mysql/mysql-slow.log(路径可自定义,确保 MySQL 进程有写权限)
  • long_query_time = 1(单位:秒,支持小数如 0.5)
  • 保存后执行 sudo systemctl restart mysqld(或 service mysql restart

验证与初步排查

开启后别急着查业务 SQL,先做两件事验证是否正常工作:

  • 执行一条人为慢 SQL:select SLEEP(3);(确保超出了你设的 long_query_time
  • 查看日志是否记录:sudo tail -n 20 /var/log/mysql/mysql-slow.log
  • 统计当前慢查询总数:SHOW GLOBAL STATUS LIKE ‘Slow_queries’;
  • 若日志为空但 Slow_queries 计数增长,说明日志路径权限或格式有误;若两者都无变化,检查是否漏写了 [mysqld] 头部或配置语法错误

这一步做完,你就拥有了性能问题的第一手证据源。后续只需结合 EXPLaiN 分析执行计划、用 mysqldumpslowpt-query-digest 聚类高频慢 SQL,优化就有的放矢了。

站长
版权声明:本站原创文章,由 站长 2025-12-22发表,共计1173字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
1a44ec70fbfb7ca70432d56d3e5ef742
text=ZqhQzanResources