暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

MySql慢查询日志分析

非功能之路 2021-06-10
2326

引言:

MySql慢查询日志是记录执行时间较长或未走索引的SQL语句的日志,本文介绍了慢查询日志的作用、参数查看及设置方式、分析方法,希望能给使用MySql的读者带来帮助。

1. 慢查询日志的作用

打开MySql慢查询日志后,Mysql可以将超过指定执行时间的以及没有使用索引的sql语句记录下来,后续可以使用explain命令查看存在问题的sql语句的执行顺序等信息,定位sql瓶颈,并进一步进行优化。

2. 查看慢查询日志相关参数值

(1)查看慢查询日志是否开启

show variables like "slow%";


"slow_launch_time" 表示建立慢查询线程超过了该指定时间,将增加慢查询线程,此时slow_launch_threads 计数器将增加;

"slow_query_log" 为"ON"表示已打开,为"OFF"表示未打开;

"slow_query_log_file" 为慢查询日志的存放目录。

(2)查看慢查询时间阈值

show variables like "long%";

long_query_time=2表示sql查询时间超过2秒才写入慢查询日志。

(3)查看是否记录未使用索引的语句

show variables like "log_queries_not_using_indexes";

"ON"表示已打开,为"OFF"表示未打开。

3. 开启慢查询日志

开启日志的方式有两种,一种是使用命令行设置变量,另一种是直接在配置文件中添加变量。

(1)修改配置文件:

在配置文件my.cnf或my.ini中在[mysqld]一行下面加入以下配置参数

slow_query_log_file=/data/mysqldata/slow-query.log

long_query_time=2

log_queries_not_using_indexes

注:my.ini在windows中的安装目录一般为"C:\ProgramData\MySQL\MySQL Server 5.7"

slow_query_log_file参数为慢查询日志存放的位置,一般这个目录要有mysql运行帐号的可写权限,一般都将这个目录设置为mysql的数据存放目录;

log_queries_not_using_indexes参数,表示记录下没有使用索引的查询。

(2)使用命令行设置变量:

// 开启慢查询日志

set global slow_query_log=ON;

// 设置慢查询语句时间阈值

set long_query_time=0.1;

// 记录未使用索引的sql语句

set log_queries_not_using_indexes=ON

4. 分析慢查询日志

(1)直接查看慢日志中记录的各个SQL得知哪些SQL执行效率低下

[root@localhost mysql]# more slow-query.log

# Time: 081026 19:46:34

# User@Host: root[root] @ localhost []

# Query_time: 11 Lock_time: 0 Rows_sent: 1 Rows_examined: 6552961

select count(*) from t_user;

(2)使用mysqldumpslow工具

如果慢查询日志中记录内容很多,可以使用mysqldumpslow工具(MySQL客户端安装自带)来对慢查询日志进行分类汇总。

进入log的存放目录,运行

[root@mysql_data]#mysqldumpslow slow-query.log

Reading mysql slow query log from slow-query.log

Count: 2 Time=11.00s (22s) Lock=0.00s (0s) Rows=1.0 (2), root[root]@mysql

select count(N) from t_user;

 mysqldumpslow命令:

/path/mysqldumpslow -s c -t 10 /database/mysql/slow-query.log

这会输出记录次数最多的10条SQL语句,其中:

-s, 是表示按照何种方式排序,c、t、l、r分别是按照记录次数、时间、查询时间、返回的记录数来排序,ac、at、al、ar,表示相应的倒叙;

-t, 是top n的意思,即为返回前面多少条的数据;

-g, 后边可以写一个正则匹配模式,大小写不敏感的;

例如:

/path/mysqldumpslow -s r -t 10 /database/mysql/slow-log

得到返回记录集最多的10个查询。

/path/mysqldumpslow -s t -t 10 -g “left join” /database/mysql/slow-log

得到按照时间排序的前10条里面含有左连接的查询语句。

使用mysqldumpslow命令可以非常明确的得到各种我们需要的查询语句,对MySQL查询语句的监控、分析、优化是MySQL优化非常重要的一步。开启慢查询日志后,由于日志记录操作,在一定程度上会占用CPU资源影响mysql的性能,但是可以阶段性开启来定位性能瓶颈。

文章转载自非功能之路,如果涉嫌侵权,请发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论