开启mysql慢查询日志mysql
修改/etc/mysql/my.cnf配置文件,添加:sql
[mysqld]
slow_query_log = on
slow_query_log_file = /var/lib/mysql/slow.log
long_query_time = 2数据库
参数详解:spa
slow_query_log = on #开启慢查询日志(或设置1) slow_query_log_file = filename #指定日志文件保存路径,不指定的话默认在数据库文件目录下,名为hostname-slow.log long_query_time = 2 #表示慢查询阈值,SQL执行时间超过该值,则会记录到慢查询日志中。SQL的执行耗时不包含锁等待时间。 log_queries_not_using_indexes=on #记录没有使用索引的查询语句。!可能致使日志文件激增,谨慎使用。配合log_throttle_queries_not_using_indexes 使用。 log_throttle_queries_not_using_indexes #表示每分钟容许记录到slow log的且未使用索引的sql语句次数。配合long_queries_not_using_indexes开启使用。 min_examined_row_limit = 1000 #对于查询扫描行数小于此参数的SQL,将不会记录到慢查询日志中; log_slow_admin_statements #管理语句执行时间大于阈值也将写入到慢查询日志中,管理语句包括alter table, check table等等; log_slow_slave_statements #从库应用binlog,若是binlog格式是statement,执行时间超过阈值时,将写入从库的慢查询日志, 对于ROW格式binlog,无论执行时间有没有超过阈值,都不会写入到从库的慢查询日志。 其中min_examined_row_limit参数表示SQL执行过程当中扫描的行数阈值,若是扫描的行数小于该参数设置的值,即便SQL执行耗时大于慢查询阈值,也不会记录到慢查询日志中,该参数默认值为0。
配置结束以后,须要重启才会生效。rest
service mysqld restart
登录数据库查询下环境日志
show variables like '%query%';
执行一个慢查询语句code
select sleep(3);
查看文件,看日志是否生成。blog