MySQL slow_query_log慢查询日志配置详解
发布日期:2025-04-15 14:50:35 浏览次数:6 分类:精选文章

本文共 1105 字,大约阅读时间需要 3 分钟。

slow query log 配置指南

slow query log 是用来记录执行时间过长的 SQL 语句的重要工具。通过及时发现和处理这些长时间运行的查询,可以显著改善数据库性能。以下是关于 slow query log 的配置方法和相关变量的详细说明。


1. 命令行参数

在 MySQL 中,可以通过命令行参数来启用并配置 slow query log。

  • --log-slow-queries
    这个参数用于指定 slow query log 的日志文件位置。如果文件路径为空,系统会自动生成一个缺省文件,文件名为 host_name-slow.log

2. 系统变量

slow query log 的配置还依赖于一些系统变量。以下是常用的配置项:

  • log_slow_queries

    这个变量控制 slow query log 的开关。当值为 1 时,slow query log 功能被启用。

  • slow_query_log

    当这个变量设置为 1 时,slow query log 功能被启用。默认值通常为 1。

  • slow_query_log_file

    这个变量用于指定 slow query log 的日志文件位置。如果未指定路径,系统会生成 host_name-slow.log 这个缺省文件。

  • long_query_time

    这个变量设置了阈值,用于判断哪些查询需要被记录。默认值为 10 秒。如果查询的执行时间超过这个值,就会被记录到 slow query log 中。

  • log_queries_not_using_indexes

    这个变量控制是否记录没有使用索引的查询。如果需要,可以根据数据库需求启用或禁用。


3. 配置方法

在 MySQL 5.1 及以上版本中,slow query log 的配置主要通过修改 MySQL 配置文件完成。

修改 /etc/my.cnf

在配置文件中添加以下内容:

[mysqld]# 启用 slow query logslow_query_log = 1slow_query_log_file = '/var/log/mysql/slow.log'long_query_time = 10log_queries_not_using_indexes = 1

保存并应用配置文件后,重启 MySQL 服务:

sudo systemctl restart mysql

总结

通过以上配置,slow query log 会自动记录执行时间超过 long_query_time 的查询。这些日志可以帮助数据库管理员识别性能瓶颈,优化数据库查询计划,从而提升整体性能。

上一篇:MySQL SQL 优化指南:主键、ORDER BY、GROUP BY 和 UPDATE 优化详解
下一篇:mysql slave 停了_slave 停止。求解决方法

发表评论

最新留言

路过按个爪印,很不错,赞一个!
[***.219.124.196]2025年05月22日 03时15分14秒