Jquery中文网 www.jquerycn.cn
Jquery中文网 >  数据库  >  mysql  >  正文 MySQL slow_query_log慢查询日志配置详解

MySQL slow_query_log慢查询日志配置详解

发布时间:2017-03-06   编辑:www.jquerycn.cn
jquery中文网为您提供MySQL slow,query,log慢查询日志配置详解等资源,欢迎您收藏本站,我们将为您提供最新的MySQL slow,query,log慢查询日志配置详解资源
顾名思义,慢查询日志中记录的是执行时间较长的query,也就是我们常说的slow query,通过设--log-slow-queries[=file_name]来打开该功能并设置记录位置和文件名,默认文件名为hostname-slow.log,默认目录也是数据目录

slow_query_log是记录SQL执行超过一定时间的参数。

slow query log相关变量

1、命令行参数:

    --log-slow-queries

    指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log

2、系统变量

    log_slow_queries

    指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log

    slow_query_log

    slow quere log的开关,当值为1的时候说明开启慢查询。

    slow_query_log_file

    指定日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.log

    long_query_time

    记录超过的时间,默认为10s

    log_queries_not_using_indexes

    log下来没有使用索引的query,可以根据情况决定是否开启

发现执行时间过长的SQL,有效的改善数据库的性能时,非常有用的参数。

在这里介绍MySQL版本5.1以上里的配置方法。

修改/etc/my.cnf

slow_query_log : 有效(0或者OFF)、无效(1或者ON)
slow_query_log_file : 指定日志文件
long_query_time : 超过指定时间的SQL会记录到日志文件(默认时间为10秒)
※MySQL5.1可以指定1秒以下的时间。

# vi /etc/my.cnf
[mysqld]

slow_query_log = 1
slow_query_log_file = /data/log/mysql/slow_query.log
long_query_time = 5

使用set global

# mysql -u<用户名> -p <数据库名>
Enter password: [输入密码]

set global slow_query_log = 1;
set global slow_query_log_file = ‘/data/log/mysql/slow_query.log';
set global long_query_time = 5;

配置有效化

重启MySQL或者set global以后,配置才会有效。

总结

因数据库的响应慢导致整个系统的响应慢的情况非常多,推荐大家安装MySQL以后有效化slow_query_log。

您可能感兴趣的文章:
如何开启mysql和php慢日志
MySQL slow_query_log慢查询日志配置详解
用MySQL慢日志分析解决MySQL CPU占用高的问题
MySQL 慢查询文件清空教程
mysql开启慢查询以检查查询慢的语句
学习开启mysql慢查询与分析查询语句
mysql优化之如何定位效率较低的SQL
mysql慢查询开启与配置
mysql中使用limit时,explain带来的问题分析
mysql开启慢查询日志的方法

[关闭]