一、什么慢查询日志
当mysql中运行的sql的时间达到一个阈值时,就会把这个sql语句记录下来。这个记录就是慢查询日志。
二、 配置my.cnf文件
#### slow log 慢查询日志 ####
slow_query_log = 1 ## 开启慢查询日志
slow_query_log_file = slow.log ## 慢查询日志文件名称
long_query_time = 2 ##sql 语句超过2s就记录
min_examined_row_limit = 100 ## sql执行中examined_row 取出数据必须大于100行才会记录
log-queries-not-using-indexes ## 没有使用索引SQL的sql记录到慢查询
log_throttle_queries_not_using_indexes = 5 ## 限制每分钟记录没有使用索引Sql的次数 意思就是:一条sql语句一直在记录 记录太多了 占存储 一分钟只记录5次
log-slow-admin-statements = table ##记录管理的操作,例如alter | analyze talbe 命令
log_output = file ## 记录慢查询日志的格式 FILE|TABLE|NONE 默认是文件格式 TABLE 是以表的格式 不建议用table
log_timestamps = 'system' ## 慢日志记录的时间格式 采用系统的时间
当我们在my.cnf配置好以后,必须要重启mysql才可以生效,
也可以通过修改全局变量来开启,但是这种方案是不能持久化的,mysql重启后就失效了。
set global slow_query_log = 1; 上面的变量都可以通过set global 方式修改。
三、 查看慢日志文件
慢日志文件默认是在我们配置的data_dir目录下面的机器名+-slow.log文件
如果我们配置了slow_query_log_file就是自己的文件路径了
可以发现这个文件就是一个txt文件,里面的记录如下:
Time:sql执行的时间 这里的时间时区是不对的,可以通过log_timestamps = system设置
Query_time是sql的运行时间, Lock_time是sql锁住的时间 Row_wxamined: 表示这个sql读取行数 Rows_sent:返回的行总数
① 当我们的日志文件特别大的时候怎么读取,例如可能文件有几个G,我们怎么看数据了?
tail -n 10000 slow.log > 1.log
## 通过tail把最后10000行的数据放到新的日志文件中,这样就可以查看了。
② 当慢日志文件比较大了,这时候需要清空文件怎么处理了?
这里肯定是不能直接用linux的命令 rm 删除的,因为当前的文件句柄是跟mysql绑定的,如果删除的话,也还是绑定的。
正确的做法是:先备份 mv slow.log slow.log.2022.02.01, 然后在mysql的命令窗口执行 flush slow logs; 命令,这个时候才会产生新的日志文件。