MySQL慢查询日志的设置

慢查询日志相关参数:

  • slow_query_log:是否开启慢查询日志,1表示开启,0表示关闭。
  • log-slow-queries:旧版(5.6以下版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
  • slow-query-log-file:新版(5.6及以上版本)MySQL数据库慢查询日志存储路径。可以不设置该参数,系统则会默认给一个缺省的文件host_name-slow.log
  • long_query_time:慢查询阈值,当查询时间多于设定的阈值时,记录日志。
  • log_queries_not_using_indexes:未使用索引的查询也被记录到慢查询日志中(可选项)。
  • log_output:日志存储方式。log_output='FILE'表示将日志存入文件,默认值是'FILE'。log_output='TABLE'表示将日志存入数据库,这样日志信息就会被写入到mysql.slow_log表中。MySQL数据<br>库支持同时两种日志存储方式,配置的时候以逗号隔开即可,如:log_output='FILE,TABLE'。日志记录到系统的专用日志表中,要比记录到文件耗费更多的系统资源,因此对于需要启用慢查询日志,又需<br>要能够获得更高的系统性能,那么建议优先记录到文件。
#是否开启慢查询日志
show variables like '%slow_query_log%';
set global slow_query_log=1;
#记录到慢查询日志的时间阀
show variables like 'long_query_time';
set global long_query_time=1;
#指定日志的存储方式
show variables like '%log_output%';
set global log_output='FILE,TABLE';
#未使用索引的查询也被记录到慢查询日志中
show variables like 'log_queries_not_using_indexes';
set global log_queries_not_using_indexes=1;
#查询有多少条慢查询记录
show global status like '%slow_queries%';
#是否将慢管理语句例如ANALYZE TABLE和ALTER TABLE等记入慢查询日志
show variables like '%log_slow_admin_statements%';

猜你喜欢

转载自blog.csdn.net/qq_42239765/article/details/90755780