MySQL如何开启慢查日志

小编给大家分享一下MySQL如何开启慢查日志,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

在开发项目中,我们可以通过MysqL的慢查询日志对有效率问题的sql进行监控。

下面一些命令是开启日志:

查找慢查询日志文件的目录

show variables like 'slow_query_log'

设置慢日志文件目录文件

set global slow_query_log_file='home/MysqL/sql_log/MysqL_slow.log'

是否把没有使用索引的sql记录在日志中

set global log_queries_not_using_indexes=on

设置超过多少秒的sql记录在日志中

set global long_query_time=1

在这里这个时间通常比较大,最好设置在0.01s比较好,更具自己的情况而定。

下面我们实际的来执行一下命令:

首先查看日志文件位置:

MySQL如何开启慢查日志

可以看出我们的slow_query_log是off,说明我们没有开启慢查日志。

通过show variables like '%log' 命令查看日志的状态,如果我们的log_queries_not_using_indexes选项为OFF,
那我们就需要对他设置为on开启。

然后在通过命令查看long_query_time的值是否被设置,如果为0,就说明不管是什么查询都会被记录在日志当中。
这里需要注意在生成环境中,短时间可能会有大量的日志。

下面我们看下日志的存储格式:

格式如下:

#查询的执行时间
#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;

以上是“MysqL如何开启慢查日志”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程之家行业资讯频道!

相关文章

MySQL 死锁 是指两个或多个事务互相等待对方持有的锁,从而导...
在MySQL中,InnoDB引擎通过Next-Key Locking技术来解决幻读问...
在数据库事务管理中,Undo Log 和 Redo Log 是两种关键日志,...
case when概述 sql语句中的case语句与高级语言中的switch语句...
其实很简单,只是为了忘记,做个记录,用的时候方便。 不管是...
1.进入服务,找到mysql服务,在属性里找到mysql的安装路径 2...