博客
关于我
MySQL slow_query_log慢查询日志配置详解
阅读量:795 次
发布时间: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 性能优化的 9 种姿势,面试再也不怕了!
查看>>
MySql 手动执行主从备份
查看>>
Mysql 批量修改四种方式效率对比(一)
查看>>
mysql 批量插入
查看>>
Mysql 报错 Field 'id' doesn't have a default value
查看>>
MySQL 报错:Duplicate entry 'xxx' for key 'UNIQ_XXXX'
查看>>
Mysql 拼接多个字段作为查询条件查询方法
查看>>
mysql 排序id_mysql如何按特定id排序
查看>>
Mysql 提示:Communication link failure
查看>>
mysql 插入是否成功_PDO mysql:如何知道插入是否成功
查看>>
Mysql 数据库InnoDB存储引擎中主要组件的刷新清理条件:脏页、RedoLog重做日志、Insert Buffer或ChangeBuffer、Undo Log
查看>>
mysql 数据库中 count(*),count(1),count(列名)区别和效率问题
查看>>
mysql 数据库备份及ibdata1的瘦身
查看>>
MySQL 数据库备份种类以及常用备份工具汇总
查看>>
mysql 数据库存储引擎怎么选择?快来看看性能测试吧
查看>>
MySQL 数据库操作指南:学习如何使用 Python 进行增删改查操作
查看>>
MySQL 数据库的高可用性分析
查看>>
MySQL 数据库设计总结
查看>>
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>