MySQL慢查询定位方式:
- 查看是否开启慢查询功能:
mysql> show variables like 'slow_query%';
+---------------------+------------------------------------+
| Variable_name | Value |
+---------------------+------------------------------------+
| slow_query_log | OFF |
| slow_query_log_file | /var/lib/mysql/instance-1-slow.log |
+---------------------+------------------------------------+
2 rows in set (0.01 sec)
mysql> show variables like 'long_query_time';
+-----------------+-----------+
| Variable_name | Value |
+-----------------+-----------+
| long_query_time | 10.000000 |
+-----------------+-----------+
1 row in set (0.00 sec)
说明:
slow_query_log 慢查询开启状态
slow_query_log_file 慢查询日志存放的位置(这个目录需要MySQL的运行帐号的可写权限,一般设置为 MySQL的数据存放目录)
long_query_time 查询超过多少秒才记录
-
可以通过set global variable_name = ‘ ’的方式临时开启或者修改配置文件来开启
-
得到具体的慢查询后,再剖析单条查询的耗时情况
1.set proiling = 1; – 开启query profile
2.执行你的查询
3.show proflies; --查看所有查询对应的profile
4.show profile for query queryId; --根据第三步的queryId获取profile的内容