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

你可能感兴趣的文章
Nginx 配置服务器文件上传与下载
查看>>
Nginx 配置清单(一篇够用)
查看>>
Nginx 配置解析:从基础到高级应用指南
查看>>
Nginx 集成Zipkin服务链路追踪
查看>>
nginx 集群配置方式 静态文件处理
查看>>
nginx+php的搭建
查看>>
nginx+tomcat+memcached
查看>>
Nginx+Tomcat实现动静分离
查看>>
nginx+Tomcat性能监控
查看>>
nginx+uwsgi+django
查看>>
nginx+vsftp搭建图片服务器
查看>>
Nginx-http-flv-module流媒体服务器搭建+模拟推流+flv.js在前端html和Vue中播放HTTP-FLV视频流
查看>>
nginx-vts + prometheus 监控nginx
查看>>
nginx: [emerg] getpwnam(“www”) failed 错误处理方法
查看>>
nginx:Error ./configure: error: the HTTP rewrite module requires the PCRE library
查看>>
Nginx、HAProxy、LVS
查看>>
Nginx下配置codeigniter框架方法
查看>>
Nginx中使用expires指令实现配置浏览器缓存
查看>>
Nginx之二:nginx.conf简单配置(参数详解)
查看>>
Nginx代理websocket配置(解决websocket异常断开连接tcp连接不断问题)
查看>>