MySQL 慢查询的相关参数解释:
(1)slow_query_log :是否开启慢查询日志,1表示开启,0表示关闭。
(2)log-slow-queries:旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
(3)slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
(4)long_query_time:慢查询阈值,当查询时间多于设定的阈值时,记录日志。
(5)log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。
(6)log_output:日志存储方式。log_output=‘FILE’表示将日志存入文件,默认值是’FILE’。log_output='TABLE’表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需要能够获得更高的系统性能,那么建议优先记录到文件。(FILE,TABLE中间不要有空格)
注:此处引用于Mysql技术内幕
1、查询MySQL版本

2、查询慢查询日志是否开启及存放位置(ON代表开启)
mysql> show global variables like '%slow_query_log%' \g

3、开启慢查询日志
mysql> set global slow_query_log=1 \g

4、查询慢查询的时间延迟阈值,只有大于此值的会被记录
注:从MySQL 5.1开始,long_query_time开始以微秒记录SQL语句运行时间,之前仅用秒为单位记录。如果记录到表里面,只会记录整数部分,不会记录微秒部分
mysql> show global VARIABLES like ‘long_query_time’ \g
±----------------±---------+
| Variable_name | Value |
±----------------±---------+
| long_query_time | 4.000000 |
±----------------±---------+
1 row in set, 1 warning (0.00 sec)
5、设置慢查询的时间阈值
mysql> set global long_query_time=4 \g
6、查询慢查询的输出格式,默认file
mysql> show global variables like '%log_output%' \g
7、设置全局的输出格式为Table
mysql> set global log_output = 'TABLE' \g
8、语句测试
mysql> select SLEEP(7) \g

9、查询慢查询的详细信息
mysql> SELECT * from mysql.slow_log \g


2294

被折叠的 条评论
为什么被折叠?



