代码改变世界

MySQL-慢查询日志

  abce  阅读(353)  评论(0编辑  收藏  举报

慢查询日志功能默认不开启,其记录了执行时间超过参数long_query_time的值(默认是10),且访问的行数超过了参数min_examined_row_limit的值得SQL语句。

1
2
3
4
5
6
7
mysql> show variables like 'long_query_time'\G
*************************** 1. row ***************************
Variable_name: long_query_time
        Value: 10.000000
1 row in set (0.00 sec)
 
mysql>

获取表的锁的时间不算在sql执行时间内。语句执行结束后,才会写到慢查询日志。

 

1.开启慢查询日志功能(不同版本开启方法不一样)

5.1.6之前版本:

  --log-slow-queries[=file_name]
5.1.12版本:

  --slow_query_log[={0|1}] 
5.1.29版本

  --slow_query_log[={0|1}]

  --slow_query_log_file=file_name

1
2
3
4
5
6
7
8
9
10
mysql> show variables like 'slow_query%';
+---------------------+---------------------------------+
| Variable_name       | Value                           |
+---------------------+---------------------------------+
| slow_query_log      | ON                              |
| slow_query_log_file | /var/mysql/data/dbtest-slow.log |
+---------------------+---------------------------------+
2 rows in set (0.00 sec)
 
mysql>

 

2.慢查询日志格式

慢查询日志可以以file格式输出,也可以以数据库表格式输出

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
mysql> show variables like 'log_output';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_output    | FILE  |
+---------------+-------+
1 row in set (0.00 sec)
 
mysql> set global log_output='table';
Query OK, 0 rows affected (0.00 sec)
 
mysql> show variables like 'log_output';
+---------------+-------+
| Variable_name | Value |
+---------------+-------+
| log_output    | TABLE |
+---------------+-------+
1 row in set (0.00 sec)
 
mysql>

设置为table格式后,输出内容在mysql.slow_log表中。

此外,可以使用mysqldumpslow工具分析慢查询日志

3.缺省的慢查询日志名字为

  host_name-slow.log

4.与慢查询有关的参数
如果运行的语句没有使用索引,开启log_queries_not_using_indexes后,数据库会将sql语句记录到慢查询日志文件中。

1
2
3
4
5
6
7
8
9
mysql> show variables like 'log_queries_not_using_indexes';
+-------------------------------+-------+
| Variable_name                 | Value |
+-------------------------------+-------+
| log_queries_not_using_indexes | OFF   |
+-------------------------------+-------+
1 row in set (0.00 sec)
 
mysql>

MySQL 5.6.5新增了一个参数log_throttle_queries_not_using_indexes,表示每分钟允许记录到slow log的且未使用索引的sql语句次数,默认是0,表示没有限制。

编辑推荐:
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
点击右上角即可分享
微信分享提示