在开发项目中,我们可以通过MySQL的慢查询日志对有效率问题的SQL进行监控。
下面一些命令是开启日志:
查找慢查询日志文件的目录
1
|
show variables like 'slow_query_log'
|
设置慢日志文件目录文件
1
|
|
是否把没有使用索引的sql记录在日志中
1
|
set global log_queries_not_using_indexes= on
|
设置超过多少秒的sql记录在日志中
1
|
set global long_query_time=1
|
在这里这个时间通常比较大,最好设置在0.01s比较好,更具自己的情况而定。
下面我们实际的来执行一下命令:
首先查看日志文件位置:
可以看出我们的slow_query_log是off,说明我们没有开启慢查日志。
通过show variables like '%log'
命令查看日志的状态,如果我们的log_queries_not_using_indexes选项为OFF,
那我们就需要对他设置为on开启。
然后在通过命令查看long_query_time的值是否被设置,如果为0,就说明不管是什么查询都会被记录在日志当中。
这里需要注意在生成环境中,短时间可能会有大量的日志。
下面我们看下日志的存储格式:
格式如下:
1
2
3
4
5
6
7
8
9
10
|
#查询的执行时间
# Time :140606 12:30:17
#SQL执行的主机信息
# User @Host:root[root] @ localhost []
#SQL的执行信息,查询执行时间 锁定时间 发送的行数和扫描的行数
#Query_time:0.000031 Locak_time:0.000000 Rows_sent:0 Rows_examined:0
#SQL执行时间
SET timestamp =1402029017;
#执行的SQL内容
show tables;
|
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对服务器之家的支持。
原文链接:http://small.aiweimeng.top/index.php/archives/65.html