阅读 229

MySQL慢查询日志如何开启以及分析

这是我参与更文挑战的第5天,活动详情查看: 活动链接

1、MySQL慢查询日志是什么

(1)MySQL的慢查询日志是MySQL提供的一种日志记录,它用来记录MySQL中查询时间超过(大于)设置阈值(long_query_time)的语句,记录到慢查询日志中。

(2)long_query_time的默认值是10。

2、如何开启MySQL慢查询日志

默认情况下,MySQL没有开启慢查询日志。需要手动打开,如果不是调优需要的话,不建议开启,因为开启会带来一定的性能影响,慢查询日志支持将日志记录写入文件。

(1)开启设置

-- 查看慢查询日志是否开启
show variables like '%slow_query_log%';
复制代码

在这里插入图片描述

-- 开启慢查询日志,只对当前数据库生效,并且重启数据库后失效
set global slow_query_log = 1;
复制代码

在这里插入图片描述

-- 查看慢查询日志的阈值,默认10s
show variables like '%long_query_time%';
复制代码

在这里插入图片描述

-- 设置阈值
set long_query_time = 3;
复制代码

在这里插入图片描述 (2)如果需要永久生效则修改配置文件my.cnf

[mysqld]
slow_query_log=1
slow_query_log_file=/var/lib/mysql/atguigu-slow.log
long_query_time=3
log_output=FILE
复制代码

(3)运行慢查询sql,查看慢查询日志

select sleep(4);
复制代码

在这里插入图片描述 (4)查询当前系统有多少条慢查询记录

show global status like '%Slow_queries%';
复制代码

在这里插入图片描述

3、日志分析工具mysqldumpslow

慢查询日志多了,不利于我们进行分析。mysqldumpslow能将相同的慢SQL归类,并统计出相同的SQL执行的次数,每次执行耗时多久、总耗时,每次返回的行数、总行数,以及客户端连接信息等。

通过 --help命令,就能知道如何使用Mysqlsumpslow 在这里插入图片描述

  • -s 表示按何种方式排序。
  • c 访问次数。
  • l 锁定时间。
  • r 返回记录。
  • t 查询时间。
  • al 平均锁定时间。
  • ar 平均返回记录数。
  • at 平均查询时间。
  • -t 返回前面多少条数据。
  • -g 后面搭配一个正则匹配模式,大小写不敏感。
# 得到返回记录集最多的10 个SQL
mysqldumpslow -s r -t 10 /var/lib/mysql/atguigu-slow.log

# 得到访问次数最多的10 个SQL
mysqldumpslow -s c -t 10 /var/lib/mysql/atguigu-slow.log

# 得到按照时间排序的前10 条里面含有左连接的查询语句
mysqldumpslow -s t -t 10 -g "left join" /var/lib/mysql/atguigu-slow.log

# 另外建议在使用这些命令时结合| 和more 使用,否则有可能出现爆屏情况
mysqldumpslow -s r -t 10 /var/lib/mysql/atguigu-slow.log | more
复制代码
文章分类
后端
文章标签