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