全国网站开发公司,免费做数学题的网站,网页图片保存,广州中学生网站制作慢查询日志
慢查询日志主要用来记录执行时间超过设置的某个时长的SQL语句#xff0c;能够帮助数据库维护人员找出执行时间比较长、执行效率比较低的SQL语句#xff0c;并对这些SQL语句进行针对性优化。 开启慢查询
可以在 my.cnf 文件或者 my.ini 文件中配置开启慢查询日志…慢查询日志
慢查询日志主要用来记录执行时间超过设置的某个时长的SQL语句能够帮助数据库维护人员找出执行时间比较长、执行效率比较低的SQL语句并对这些SQL语句进行针对性优化。 开启慢查询
可以在 my.cnf 文件或者 my.ini 文件中配置开启慢查询日志。 [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 命令行中执行如下命令开启慢查询日志。 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 语句。
SELECT BENCHMARK(99999999, MD5(mysql));这条语句用了大概耗时: 19.102s
我们看看慢查询日志文件的记录如下
删除慢查询日志
慢查询日志和查询日志一样以纯文本文件的形式存储在服务器磁盘中可以直接删除。如果需要重新生成慢查询日志可以在 MySQL 命令行中运行 FLUSH LOGS 命令或者在服务器命令行中执行mysqladmin flush-logs 命令。 1删除慢查询日志。
rm -rf /data/mysql/log/query_log/slow_statement.log删除后查看/data/mysql/log/query_log目录下的文件。
结果显示slow_statement.log 文件已经被成功删除。
2在 MySQL 命令行中刷新日志。
mysql FLUSH LOGS;
Query OK, 0 rows affected (0.01 sec)或者在服务器命令行中执行如下命令刷新日志。 mysqladmin -uroot -p flush-logs
Enter password:日志刷新成功后再次查看/data/mysql/log/query_log目录下的文件。
MySQL重新创建了 slow_statement.log 文件。
关闭慢查询日志
关闭慢查询日志只需要在my.cnf文件或者my.ini文件中配置slow_query_log0或者直接删除此选项即可。 [mysqld]
slow_query_log 0也可以在MySQL命令行中执行如下命令关闭慢查询日志。
mysql SET GLOBAL slow_query_log 0;
Query OK, 0 rows affected (0.00 sec)当关闭慢查询日志后删除慢查询日志文件再执行刷新日志的操作MySQL将不再重新创建慢查询日志文件。