慢查询定义
慢查询设置
-
查询慢sql时间设设置的值
show variables like ‘long%’; -
修改慢查询时间阈值
set global long_query_time=4 -
展示慢sql的开启状态和日志文件的存放位置
show variables like ‘slow%’;
slow_launch_time 2
slow_query_log ON
slow_query_log_file /root/mysql/datas/mysql/slow_query.log -
未使用索引的查询被记录到慢查询日志中。如果调优的话,建议开启这个选项。如果开启了这个参数,full index scan的sql也会被记录到慢查询日志中。
show variables like ‘log_queries_not_using_indexes’;
开启开关
set global log_queries_not_using_indexes=1 -
查询有多少条慢查询记录
show global status like ‘%Slow_queries%’;
通过explain来分析SQL性能(Mysql)
1. 什么是explain
2. explain 参数解析
【id】
【select_type】
【type】
- all:全表扫描
- index:全索引扫描
- range:范围扫描
- ref:不唯一的索引扫描,有多个符合条件的行
- eq_ref:唯一的索引扫描,只有一条记录与之匹配,常见于主键索引
- const、system:这两种的情况都比较好,前一种值的是条件为常量
- null:执行阶段不需要访问的表
【table】
- 对应的表
【possible_keys】
- 哪些索引可能有助于查询。如果为空,说明没有可用的索引
【key】
- 实际从 possible_key 选择使用的索引,如果为 NULL,则没有使用索引。很少的情况 下,MYSQL 会选择优化不足的索引。这种情 况下,可以在 SELECT语句中使用 USE INDEX (indexname)来强制使用一个索引或者用IGNORE INDEX(indexname)来强制 MYSQL 忽略索引
【key_len】
- 使用的索引的长度。在不损失精确性的情况 下,长度越短越好。
【ref】 - 这一列显示了哪些字段或者常量被用来和key配合从表中查询记录出来
【rows】 - 估计要读取的行数
【extra】 - Using index:使用覆盖索引,表示查询索引就可查到所需数据,不用扫描表数据文件,往往说明性能不错。
- Using Where:在存储引擎检索行后再进行过滤,使用了where从句来限制哪些行将与下一张表匹配或者是返回给用户。
- Using temporary:在查询结果排序时会使用一个临时表,一般出现于排序、分组和多表 join 的情况,查询效率不高,建议优化。
- Using filesort:对结果使用一个外部索引排序,而不是按索引次序从表里读取行,一般有出现该值,都建议优化去掉,因为这样的查询
CPU 资源消耗大。
优化方式
1. SQL调优
2. 优化索引的使用
3. 表结构设计优化
4. show profiles 分析sql 性能
1. show profiles功能介绍
show profile是由Jeremy Cole捐献给MySQL社区版本的。默认的是关闭的,但是会话级别可以开启这个功能。开启它可以让MySQL收集在执行语句的时候所使用的资源
2. 查看并开启功能
为了统计报表,把profiling设为1
Profiling 功能由MySQL会话变量 : profiling控制,默认是OFF.关闭状态。select @@profiling; 或者show variables like ‘%profi%’;
mysql> select @@profiling;
+-------------+
| @@profiling |
+-------------+
| 0 |
+-------------+
mysql> set profiling = 1;
Query OK, 0 rows affected, 1 warning (0.00 sec)
3. 使用方法
运行一个sql语句
SELECT passrate FROM user_center
使用
SHOW PROFILES;
show profile for QUERY [QUERYID]
来查看sql执行的详情信息
profiling_history_size 控制,默认15条
set profiling_history_size =100; 修改条数显示