MYSQL慢查询日志总结

MySQL 慢查询的相关参数解释
(1)slow_query_log :是否开启慢查询日志,1表示开启,0表示关闭。
(2)log-slow-queries:旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
(3)slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
(4)long_query_time:慢查询阈值,当查询时间多于设定的阈值时,记录日志。
(5)log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。
(6)log_output:日志存储方式。log_output=‘FILE’表示将日志存入文件,默认值是’FILE’。log_output='TABLE’表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。(FILE,TABLE中间不要有空格)
:此处引用于Mysql技术内幕

1、查询MySQL版本
在这里插入图片描述

2、查询慢查询日志是否开启及存放位置(ON代表开启)

mysql> show global variables like '%slow_query_log%'  \g

在这里插入图片描述
3、开启慢查询日志

mysql> set global slow_query_log=1 \g

在这里插入图片描述

4、查询慢查询的时间延迟阈值,只有大于此值的会被记录
注:从MySQL 5.1开始,long_query_time开始以微秒记录SQL语句运行时间,之前仅用秒为单位记录。如果记录到表里面,只会记录整数部分,不会记录微秒部分
mysql> show global VARIABLES like ‘long_query_time’ \g
±----------------±---------+
| Variable_name | Value |
±----------------±---------+
| long_query_time | 4.000000 |
±----------------±---------+
1 row in set, 1 warning (0.00 sec)

5、设置慢查询的时间阈值

mysql> set global long_query_time=4 \g

6、查询慢查询的输出格式,默认file

mysql> show global variables like '%log_output%'  \g

7、设置全局的输出格式为Table

mysql> set global log_output = 'TABLE' \g

8、语句测试

mysql> select SLEEP(7) \g

在这里插入图片描述
9、查询慢查询的详细信息

mysql> SELECT * from  mysql.slow_log \g

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值