如何合理配置MySQL Slow Query Log

数据库关系型数据库技术服务知识库
问题描述

如何正确配置 MySQL 的 slow query log?

常见参数说明

1.min_examined_row_limit

测试配置文件如下

###slow_log
long_query_time=1      //条件1:时间需要大于1s
slow_query_log=1
slow_query_log_file=/data/3306/data/slow.log
min_examined_row_limit=2000             //条件2:检查扫描的行数>2000
log_queries_not_using_indexes=1    
```
`
需要同时满足条件1和条件2才会被记录到slow.log中,利用benchmark函数来验证
````undefined
mysql> select benchmark(100000000,1000000*1000000);
+--------------------------------------+
| benchmark(100000000,1000000*1000000) |
+--------------------------------------+
|                                    0 |
+--------------------------------------+
1 row in set (1.44 sec)

```
`
执行时间为1.44秒但是没有被记录到slow.log日志中
注释掉min_examined_row_limit参数后,slow.log中会有日志记录如下
````undefined
# Time: 2021-10-29T02:10:58.593293Z
# User@Host: root[root] @ localhost [127.0.0.1]  Id:     2
# Query_time: 1.439743  Lock_time: 0.000000 Rows_sent: 1  Rows_examined: 0
SET timestamp=1635473458;
select benchmark(100000000,1000000*1000000);
```
`
## 2.log_queries_not_using_indexes
即使不满足条件1(slow_query_time)和条件2(min_examined_row_limit)的条件
没有使用索引也会记录到慢日志中
示例查询语句:
````undefined
mysql> select * from mysql.db\G;
*************************** 1. row ***************************
                 Host: %
                   Db: p1_01
                 User: p1_role_readonly
          Select_priv: Y
          Insert_priv: N
          Update_priv: N
          Delete_priv: N
          Create_priv: N
            Drop_priv: N
           Grant_priv: N
      References_priv: N
           Index_priv: N
           Alter_priv: N
Create_tmp_table_priv: N
     Lock_tables_priv: N
     Create_view_priv: N
       Show_view_priv: N
  Create_routine_priv: N
   Alter_routine_priv: N
         Execute_priv: N
           Event_priv: N
         Trigger_priv: N
*************************** 2. row ***************************
                 Host: localhost
                   Db: performance_schema
                 User: mysql.session
                 ……
                 ……
```
`
slow.log日志记录(即使时间只是0.000215,检查的行数只有2行),但是因为进行了全表扫面所以也会记录到slow.log日志中。
````undefined
# Time: 2021-10-29T02:14:24.200366Z
# User@Host: root[root] @ localhost [127.0.0.1]  Id:     2
# Query_time: 0.000215  Lock_time: 0.000118 Rows_sent: 2  Rows_examined: 2
use mysql;
SET timestamp=1635473664;
select * from db;
```
`
### 2.1 log_throttle_queries_not_using_indexes
抑制未使用索引的慢查询记录(因为开了log_queries_not_using_indexes参数后日志量记录会比较多)
````undefined
配置文件如下:
###slow_log
long_query_time=1
slow_query_log=1
slow_query_log_file=/data/3306/data/slow.log
#min_examined_row_limit=2000
log_queries_not_using_indexes=1
log_throttle_queries_not_using_indexes=5   //1分钟内超过5条未时候索引的慢查询,后续的慢日志记录会抑制
```
`
测试语句,连续执行mysql> select * from db;的全表扫描语句
````undefined
慢日志记录如下:

# Time: 2021-10-29T02:30:04.440644Z      //02:30分钟的时候发生开始产生日志
# User@Host: root[root] @ localhost [127.0.0.1]  Id:     2
# Query_time: 0.000174  Lock_time: 0.000091 Rows_sent: 2  Rows_examined: 2
use mysql;
SET timestamp=1635474604;
select * from db;
# Time: 2021-10-29T02:30:10.605822Z
# User@Host: root[root] @ localhost [127.0.0.1]  Id:     2


中间大约也执行了4条,但是一直没有日志记录
//产生5条日志后,后面不在有日志输出,知道接近一分钟02:32的时候,报错throttle
# Time: 2021-10-29T02:32:08.332210Z
# User@Host: [] @  []  Id:     2
# Query_time: 0.001029  Lock_time: 0.000472 Rows_sent: 2  Rows_examined: 2
SET timestamp=1635474728;
//这里会有如下的告警,表是slowlog的日志记录已经被压缩
rottle:          6 'index not used' warning(s) suppressed.;


```
`
### 2.2 log-short-format
服务器将用较少的信息写入慢查询日志
````undefined
//修改前
# Query_time: 0.000236  Lock_time: 0.000081 Rows_sent: 2  Rows_examined: 2
SET timestamp=1635474728;
select * from db;
/usr/local/mysql/bin/mysqld, Version: 5.7.35-log (MySQL Community Server (GPL)). started with:
Tcp port: 3306  Unix socket: /data/3306/data/tmp/mysql.sock
Time                 Id Command    Argument

//修改后
# Query_time: 0.000133  Lock_time: 0.000072 Rows_sent: 2  Rows_examined: 2
use mysql;
SET timestamp=1635487528;
select * from db;

```
`
## 3.log_slow_admin_statements
ALTER TABLE, ANALYZE TABLE, CHECK TABLE, CREATE INDEX, DROP INDEX, OPTIMIZE TABLE,和 REPAIR TABLE这些语句也会被记录。
# 参考文档
[1] [https://dev.mysql.com/doc/refman/5.7/en/slow-query-log.html](https://dev.mysql.com/doc/refman/5.7/en/slow-query-log.html)
**如果您有其他问题,欢迎您联系火山引擎**[技术支持服务](https://console.volcengine.com/ticket/createTicketV2/)

0
0
0
0
评论
未登录
看完啦,登录分享一下感受吧~
暂无评论