什么是慢查询
慢查询,顾名思义,就是查询慢的sql语句,是指mysql记录所有执行超过long_query_time参数设定的时间阈值的SQL语句的日志。该日志能为SQL语句的优化带来很好的帮助。默认情况下,慢查询日志是关闭的,要使用慢查询日志功能,首先要开启慢查询日志功能。
慢查询配置
慢查询基本配置
- slow_query_log 启动停止技术慢查询日志
- slow_query_log_file 指定慢查询日志得存储路径及文件(默认和数据文件放一起)
- long_query_time 指定记录慢查询日志SQL执行时间得伐值(单位:秒,默认10秒)
- log_queries_not_using_indexes 是否记录未使用索引的SQL
- log_output 日志存放的地方【TABLE】【FILE】【FILE,TABLE】
配置了慢查询后,它会记录符合条件的SQL,包括:
- 查询语句
- 数据修改语句
- 已经回滚的SQL
通过下面命令查看下上面的配置:
-
show VARIABLES like '%slow_query_log%'
-
show VARIABLES like '%slow_query_log_file%'
-
show VARIABLES like '%long_query_time%'
-
show VARIABLES like '%log_queries_not_using_indexes%'
-
show VARIABLES like 'log_output'
-
set global long_query_time=0; -- 默认10秒,这里为了演示方便设置为0
-
set GLOBAL slow_query_log = 1; -- 开启慢查询日志
-
set global log_output='FILE' -- 项目开发中日志只能记录在日志文件中,不能记表中
慢查询日志文件分析
设置完成后,通过 show VARIABLES like 'datadir'来查看数据文件存放的位置。日志文件中的内容格式如下:
# User@Host: [root] @ localhost [127.0.0.1]
# Query_time: 0.000997
# Lock_time: 0.000000
# Rows_sent: 5
# Rows_examined: 5
SET timestamp=1539153057;
SELECT * FROM `t_users` LIMIT 0, 1000;
- 第一行:用户名 、用户的IP信息、线程ID号
- 第二行:执行花费的时间【单位:毫秒】
- 第三行:执行获得锁的时间
- 第四行:获得的结果行数
- 第五行:扫描的数据行数
- 第六行:这SQL执行的具体时间
- 第七行:具体的SQL语句
慢查询分析工具
Mysqldumpslow
linux系统在mysql的bin目录下执行
./mysqldumpslow -s r -t 5 /usr/local/mysql/data/70KG-224-slow.log
可以看出查询总时间均为0S,是因为语句查询时间太短,实际上是按时间倒序来排的。
参数说明:
mysqldumpslow -s r -t 10 slow-mysql.log
-s order (c,t,l,r,at,al,ar)
c:总次数
t:总时间
l:锁的时间
r:总数据行
at(每次执行sql耗费的时间),al(每次执行sql加锁用的时间),ar(每次获取数据行数所用时间)【例如:at = 总时间/总次数】其中a表示average平均
-t top 指定取前面几天作为结果输出
pt_query_digest
这个工具安装起来比较复杂,非专业sql人员感觉没必要玩~
网友评论