深入了解MySQL中的慢查询日志

吾爱主题 阅读:182 2023-03-19 16:44:00 评论:0

慢查询日志

慢查询日志主要用来记录执行时间超过设置的某个时长的SQL语句,能够帮助数据库维护人员找出执行时间比较长、执行效率比较低的SQL语句,并对这些SQL语句进行针对性优化。

开启慢查询

可以在 my.cnf 文件或者 my.ini 文件中配置开启慢查询日志。

?
1 2 3 4 5 [mysqld] slow_query_log = 1 slow_query_log_file = /data/mysql/log/query_log/slow_statement.log long_query_time = 10 log_output = FILE

各配置项说明如下:

slow_query_log:指定是否开启慢查询日志。指定的值为1或者不指定值都会开启慢查询日志;指定的值为 0 或者 不配置此选项就不会开启慢查询日志。

slow_query_log_file:慢查询日志的文件位置。

long_query_time:指定SQL语句执行时间超过多少秒时记录慢查询日志。

log_output:与查询日志的log_output选项相同,此处不再赘述。

注意:log_output 能够配置将日志记录到数据表中还是记录到文件中,当记录到数据表中时,则数据表中记录的慢查询时间只能精确到秒;如果是记录到日志文件中,则日志文件中记录的慢查询时间能够精确到微秒。建议在实际工作中,将慢查询日志记录到文件中。

配置完成后,重启 MySQL 服务器配置才能生效。

除了在文件中配置开启慢查询日志外,也可以在 MySQL 命令行中执行如下命令开启慢查询日志。

?
1 2 3 4 5 6 7 8 mysql> SET GLOBAL slow_query_log = 1; Query OK, 0 rows affected (0.00 sec) mysql> SET GLOBAL slow_query_log_file = '/data/mysql/log/query_log/slow_statement.log' ; Query OK, 0 rows affected (0.00 sec) mysql> SET GLOBAL long_query_time = 10; Query OK, 0 rows affected (0.00 sec) mysql> SET GLOBAL log_output = 'FILE' ; Query OK, 0 rows affected (0.00 sec)

成功开启慢查询日志后,会在 /data/mysql/log/query_log 目录下生成 slow_statement.log 文件。

查看慢查询日志

慢查询日志如果配置的是输出到文件,则会保存到纯文本文件中,直接查看纯文本文件的内容即可。

构造一个查询时间超过 10 秒的 SQL 语句。

?
1 SELECT BENCHMARK(99999999, MD5( 'mysql' ));

这条语句用了大概耗时: 19.102s

我们看看慢查询日志文件的记录如下:

删除慢查询日志

慢查询日志和查询日志一样以纯文本文件的形式存储在服务器磁盘中,可以直接删除。如果需要重新生成慢查询日志,可以在 MySQL 命令行中运行 FLUSH LOGS 命令,或者在服务器命令行中执行mysqladmin flush-logs 命令。

(1)删除慢查询日志。

?
1 rm -rf /data/mysql/log/query_log/slow_statement.log

删除后,查看/data/mysql/log/query_log目录下的文件。

结果显示,slow_statement.log 文件已经被成功删除。

(2)在 MySQL 命令行中刷新日志。

?
1 2 mysql> FLUSH LOGS; Query OK, 0 rows affected (0.01 sec)

或者在服务器命令行中执行如下命令刷新日志。

?
1 2 mysqladmin -uroot -p flush-logs Enter password :

日志刷新成功后,再次查看/data/mysql/log/query_log目录下的文件。

MySQL重新创建了 slow_statement.log 文件。

关闭慢查询日志

关闭慢查询日志,只需要在my.cnf文件或者my.ini文件中配置slow_query_log=0或者直接删除此选项即可。

?
1 2 [mysqld] slow_query_log = 0

也可以在MySQL命令行中执行如下命令关闭慢查询日志。

?
1 2 mysql> SET GLOBAL slow_query_log = 0; Query OK, 0 rows affected (0.00 sec)

当关闭慢查询日志后,删除慢查询日志文件,再执行刷新日志的操作,MySQL将不再重新创建慢查询日志文件。

到此这篇关于深入了解MySQL中的慢查询日志的文章就介绍到这了,更多相关MySQL慢查询内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://zhaoyanfei.blog.csdn.net/article/details/129203039

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容