慢查询日志功能默认不开启,其记录了执行时间超过参数long_query_time的值(默认是10),且访问的行数超过了参数min_examined_row_limit的值得SQL语句。
mysql> show variables like 'long_query_time'G *************************** 1. row *************************** Variable_name: long_query_time Value: 10.000000 1 row in set (0.00 sec) mysql>
获取表的锁的时间不算在sql执行时间内。语句执行结束后,才会写到慢查询日志。
1.开启慢查询日志功能(不同版本开启方法不一样)
5.1.6之前版本:
--log-slow-queries[=file_name]
5.1.12版本:
--slow_query_log[={0|1}]
5.1.29版本
--slow_query_log[={0|1}]
--slow_query_log_file=file_name
mysql> show variables like 'slow_query%'; +---------------------+---------------------------------+ | Variable_name | Value | +---------------------+---------------------------------+ | slow_query_log | ON | | slow_query_log_file | /var/mysql/data/dbtest-slow.log | +---------------------+---------------------------------+ 2 rows in set (0.00 sec) mysql>
2.慢查询日志格式
慢查询日志可以以file格式输出,也可以以数据库表格式输出
mysql> show variables like 'log_output'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | log_output | FILE | +---------------+-------+ 1 row in set (0.00 sec) mysql> set global log_output='table'; Query OK, 0 rows affected (0.00 sec) mysql> show variables like 'log_output'; +---------------+-------+ | Variable_name | Value | +---------------+-------+ | log_output | TABLE | +---------------+-------+ 1 row in set (0.00 sec) mysql>
设置为table格式后,输出内容在mysql.slow_log表中。
此外,可以使用mysqldumpslow工具分析慢查询日志
3.缺省的慢查询日志名字为
host_name-slow.log
4.与慢查询有关的参数
如果运行的语句没有使用索引,开启log_queries_not_using_indexes后,数据库会将sql语句记录到慢查询日志文件中。
mysql> show variables like 'log_queries_not_using_indexes'; +-------------------------------+-------+ | Variable_name | Value | +-------------------------------+-------+ | log_queries_not_using_indexes | OFF | +-------------------------------+-------+ 1 row in set (0.00 sec) mysql>
MySQL 5.6.5新增了一个参数log_throttle_queries_not_using_indexes,表示每分钟允许记录到slow log的且未使用索引的sql语句次数,默认是0,表示没有限制。