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