查询mysql慢日志是否开启

show variables like '%slow_query_log%';

WX20190415-171640@2x

开启mysql慢日志

set global slow_query_log=1;

使用set global slow_query_log=1开启了慢查询日志只对当前数据库生效,MySQL重启后则会失效。如果要永久生效,就必须修改配置文件my.cnf(其它系统变量也是如此)

查看及设置慢日志记录时间

  • 查看慢日志记录时间
    show variables like 'long_query_time';

WX20190415-171943@2x
默认为10s

  • 设置慢日志记录时间
    set global long_query_time=4;

日志输出格式

WX20190415-172128@2x
log_output 参数是指定日志的存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件.

log-queries-not-using-indexes

系统变量log-queries-not-using-indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。如果调优的话,建议开启这个选项。另外,开启了这个参数,其实使用full index scan的sql也会被记录到慢查询日志。
WX20190415-172400@2x

log_slow_admin_statements

系统变量log_slow_admin_statements表示是否将慢管理语句例如ANALYZE TABLE和ALTER TABLE等记入慢查询日志

slow_queries

如果你想查询有多少条慢查询记录,可以使用系统变量

show global status like '%slow_queries%';