博客
关于我
MySQL slow_query_log慢查询日志配置详解
阅读量:799 次
发布时间:2023-02-10

本文共 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 的查询。这些日志可以帮助数据库管理员识别性能瓶颈,优化数据库查询计划,从而提升整体性能。

转载地址:http://xrffk.baihongyu.com/

你可能感兴趣的文章
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
MySQL 事务的面试题总结
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>
MySQL 优化:Explain 执行计划详解
查看>>
Mysql 会导致锁表的语法
查看>>
mysql 使用sql文件恢复数据库
查看>>
mysql 修改默认字符集为utf8
查看>>
Mysql 共享锁
查看>>