• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

MySQL慢查日志的开启方式与存储格式详析

mysql 搞代码 4年前 (2022-01-09) 17次浏览 已收录 0个评论

在开发项目中,我们可以通过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比较好,更具自己的情况而定。

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

首先查看日志文件位置:

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

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

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

本文来源gao@dai!ma.com搞$代^码!网7面我们看下日志的存储格式:

格式如下:

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

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对搞代码的支持。


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:MySQL慢查日志的开启方式与存储格式详析
喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址