MySQL性能优化(七)-- 慢查询

1.慢查询的用途

它能记录下所有执行超过long_query_time时间的SQL语句,帮我们找到执行慢的SQL,方便我们对这些SQL进行优化。

2.查看是否开启慢查询
show variables like 'slow_query%';

在这里插入图片描述
slow_query_log = off,表示没有开启慢查询
slow_query_log_file 表示慢查询日志存放的目录

3.开启慢查询(需要的时候才开启,因为很耗性能,建议使用即时性的)
方式一:(即时性的,重启mysql之后失效,常用的)
set global slow_query_log=1;

或者

set global slow_query_log=ON;

开启之后 我们会发现 /var/lib/mysql下已经存在 localhost-slow.log了,未开启的时候默认是不存在的。

方式二:(永久性的)

在/etc/my.cfg文件中的[mysqld]中加入:

slow_query_log=ON
slow_query_log_file=/var/lib/mysql/localhost-slow.log
4.设置慢查询记录的时间

查询慢查询记录的时间:show variables like ‘long_query%’,默认是10秒钟,意思是大于10秒才算慢查询。
在这里插入图片描述
我们现在设置慢查询记录时间为1秒:

set long_query_time=1;
5.执行select count(1) from order o where o.user_id in (select u.id where users);

因为我们开启了慢查询,且设置了超过1秒钟的就为慢查询,此sql执行了24秒,所以属于慢查询。
我们在日志中查看:

more /var/lib/mysql/localhost-slow.log

在这里插入图片描述

我们可以看到查询的时间,用户,花费的时间,使用的数据库,执行的sql语句等信息。在生产上我们就可以使用这种方式来查看 执行慢的sql。

6.查询慢查询的次数:show status like ‘slow_queries’;

在这里插入图片描述
在我们重新执行刚刚的查询sql后,查询慢查询的次数会变为8
在这里插入图片描述
当然,用 more /var/lib/mysql/localhost-slow.log 也是可以看到详细结果的。
在生产中,我们会分析查询频率高的,且是慢查询的sql,并不是每一条查询慢的sql都需要分析。

7.慢查询日志分析工具Mysqldumpslow

由于在生产上会有很多慢查询,所以采用上述的方法查看慢查询sql会很麻烦,还好MySQL提供了慢查询日志分析工具Mysqldumpslow。
其功能是, 统计不同慢sql的出现次数(Count),执行最长时间(Time),累计总耗费时间(Time),等待锁的时间(Lock),发送给客户端的行总数(Rows),扫描的行总数(Rows)
(1)查询Mysqldumpslow的帮助信息,随便进入一个文件夹下,执行:mysqldumpslow --help
查看mysqldumpslow命令安装在哪个目录:

whereis mysqldumpslow

在这里插入图片描述
说明:

  • -s,是order的顺序,主要有c(按query次数排序)、t(按查询时间排序)、l(按lock的时间排序)、r (按返回的记录数排序)和 at、al、ar,前面加了a的代表平均数
  • -t,是top n的意思,即为返回前面多少条的数据
  • -g,后边可以写一个正则匹配模式,大小写不敏感的
  • -r:倒序

(2)案例:取出耗时最长的两条sql
格式:mysqldumpslow -s t -t 2 慢日志文件

mysqldumpslow -s t -t 2 /var/lib/mysql/localhost-slow.log

在这里插入图片描述
参数分析:

  • 出现次数(Count),
  • 执行最长时间(Time),
  • 累计总耗费时间(Time),
  • 等待锁的时间(Lock),
  • 发送给客户端的行总数(Rows),
  • 扫描的行总数(Rows),
  • 用户以及sql语句本身(抽象了一下格式, 比如 limit 1, 20 用 limit N,N 表示).

(3)案例:取出查询次数最多,且使用了in关键字的1条sql

mysqldumpslow -s c -t 1 -g 'in' /var/lib/mysql/localhost-slow.log

在这里插入图片描述
这种方式更加方便,更加快捷!

8.show profile

用途:用于分析当前会话中语句执行的资源消耗情况
(1)查看是否开启profile,mysql默认是不开启的,因为开启很耗性能

show variables like 'profiling%';

在这里插入图片描述
(2)开启profile(会话级别的,关闭当前会话就会恢复原来的关闭状态)

set profiling=1;

或者

set profiling=ON;

(3)关闭profile

set profiling=0;

或者

set profiling=OFF;

(4)显示当前执行的语句和时间

show profiles;

在这里插入图片描述
(5)显示当前查询语句执行的时间和系统资源消耗

show profile cpu,block io for query 4;

(分析show profiles中query_id等于4的sql所占的CPU资源和IO操作)
或者直接 :

show profile for  query 4;

在这里插入图片描述
原文链接

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值