博客
关于我
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/

你可能感兴趣的文章
logstash mysql 准实时同步到 elasticsearch
查看>>
Luogu2973:[USACO10HOL]赶小猪
查看>>
mabatis 中出现< 以及> 代表什么意思?
查看>>
Mac book pro打开docker出现The data couldn’t be read because it is missing
查看>>
MAC M1大数据0-1成神篇-25 hadoop高可用搭建
查看>>
mac mysql 进程_Mac平台下启动MySQL到完全终止MySQL----终端八步走
查看>>
Mac OS 12.0.1 如何安装柯美287打印机驱动,刷卡打印
查看>>
MangoDB4.0版本的安装与配置
查看>>
Manjaro 24.1 “Xahea” 发布!具有 KDE Plasma 6.1.5、GNOME 46 和最新的内核增强功能
查看>>
mapping文件目录生成修改
查看>>
MapReduce程序依赖的jar包
查看>>
mariadb multi-source replication(mariadb多主复制)
查看>>
MariaDB的简单使用
查看>>
MaterialForm对tab页进行隐藏
查看>>
Member var and Static var.
查看>>
memcached高速缓存学习笔记001---memcached介绍和安装以及基本使用
查看>>
memcached高速缓存学习笔记003---利用JAVA程序操作memcached crud操作
查看>>
Memcached:Node.js 高性能缓存解决方案
查看>>
memcache、redis原理对比
查看>>
memset初始化高维数组为-1/0
查看>>