MySQL的日志分析详解三(MySQL慢日志)

1、作用

记录消耗时间比较长的SQL语句,为数据库性能提升提供了线索

例如:
最近数据库压力(负载特别高),客户反应网站或者应用使用特别慢,领导要求你查明原因?

  • 1.SQL语句需要优化,在数据库里启用慢日志,找出执行时间比较长的SQL

  • 2.业务量太大了,硬件已经达到极限了 ,top、glances、dstat

2、默认是关闭的

mysql> show variables like "%slow_query%";

+---------------------+---------------------------------------+

| Variable_name       | Value                                 |

+---------------------+---------------------------------------+

| slow_query_log      | OFF                                   |

| slow_query_log_file | /data/mysql/zabbix-4-centos7-slow.log |

+---------------------+---------------------------------------+

2 rows in set (0.01 sec)



mysql> 

3、修改配置文件

#slow query log

slow_query_log = 1
long_query_time = 0.001 #标准
  • 默认的
mysql> show variables like "%long_query%";

+-----------------+----------+

| Variable_name   | Value    |

+-----------------+----------+

| long_query_time | 10.000 |

+-----------------+----------+

1 row in set (0.00 sec)



mysql> 
  • 修改的
mysql> show variables like "%long_query%";

+-----------------+----------+

| Variable_name   | Value    |

+-----------------+----------+

| long_query_time | 0.001000 |

+-----------------+----------+

1 row in set (0.00 sec)



mysql> 

4、存放路径

存放在数据目录下,名字是主机名+slow.log

你可能感兴趣的:(MySQL)