MySQL慢查询日志优化实战

1、定位执行慢的SQL:慢查询日志

慢查询日志是记录在MySQL中响应时间超过阈值的语句,具体是说超过long_query_time(他的值默认是10)值的SQL。主要作用是帮助发现那些执行时间特别长的SQL查询,并有针对性的进行优化,从而提高系统整体效率。

默认情况下,MySQL数据库没有开启慢查询日志,如果使用的话需要提前开启。但是如果不是调优需要的话,一般不建议启动该参数,这会带来一定的性能影响。

1.1 开启慢查询日志参数

(1)开启slow_query_log

sql 复制代码
set global slow_query_log = on;

同时,也能看到慢查询日志的文件在/var/lib/mysql/master-slow.log中。

(2)修改long_query_time阈值

将阈值时间设置为1秒,同时对global以及session设置时间。

sql 复制代码
set global long_query_time = 1;

set long_query_time=1;

这是临时修改的,如果想永久设置就必须去配置文件中设置。

1.2 查看慢查询的条数

sql 复制代码
SHOW GLOBAL STATUS LIKE '%Slow_queries%';

1.3 测试分析

(1)测试

新建两个查询,查询时间都大于我们设置的阈值1秒:

sql 复制代码
SELECT * FROM student WHERE stuno = 3455655;
sql 复制代码
SELECT * FROM student WHERE name = 'uPSQCp';

(2)分析

查看慢查询的个数:

sql 复制代码
show status like 'slow_queries'; # 2

1.4 慢查询日志分析工具 mysqldumpslow

sql 复制代码
mysqldumpslow -s t -t 5 /var/lib/mysql/master-slow.log

参数说明:-s是表示按照何种方式排序(t代表查询时间);-t代表返回前面多少条数据;-a表示不把数字抽形成N,字符串抽象成S。如需了解其他用法,可通过执行"mysqldumpslow --help"命令查看详细帮助信息。

1.5 关闭慢查询日志

情况一:如果是在配置文件永久性设置的

sql 复制代码
# ①
slow_query_log=OFF

# ②把slow_query_log一项注释掉 或 删除
# slow_query_log=OFF

然后重启MySQL服务(systemctl restart mysqld)。

情况二:如果是临时性修改的

sql 复制代码
SET GLOBAL slow_query_log=off;

重启MySQL服务,可以查看慢查询日志功能信息:

sql 复制代码
SHOW VARIABLES LIKE '%slow%';
#以及
SHOW VARIABLES LIKE '%long_query_time%';

1.6 删除慢查询日志文件

(1)手动删除慢查询日志文件

(2)重新生成查询日志文件

sql 复制代码
mysqladmin -uroot -p flush-logs slow

如果设置完还没有发现重置后的日志文件,是因为当前状态的慢查询状态是OFF。

2、查看SQL执行成本 SHOW PROFILE

(1)启动show profile

sql 复制代码
 set profiling = 'ON';

(2)当前会话有哪些profiles

sql 复制代码
show profiles;

(3)查看最近一次查询的开销

sql 复制代码
show profile;

(4)查看具体资源消耗

sql 复制代码
show profile cpu,block io for query 2;
相关推荐
李白客17 分钟前
KES新版MySQL兼容能力再升级意味着什么?
mysql·国产数据库
ClouGence3 小时前
Oracle 数据同步为什么会出现数据不一致?长事务是常被忽略的原因
数据库·后端·oracle
飞将5 小时前
从零实现数据库(2)——HashIndex + IndexManager
数据库
Nturmoils1 天前
订单列表慢查询,先看 WHERE、ORDER BY 和 LIMIT
数据库
渣波1 天前
拒绝 SQL 焦虑!手把手带你用 NestJS + Prisma + DTO 写出“防弹”级后端代码
javascript·数据库·后端
Jim6002 天前
【吃透 MySQL InnoDB连载】第 1 章・解密线上数据库高频故障
mysql
TrisighT2 天前
Electron 跑在鸿蒙 PC 上,单窗口和多窗口内存差 800MB?我抓了 5 组数据
性能优化·electron·harmonyos
GreatSQL2 天前
gt-checksum v4.0.0 新功能解读系列文章(4):SSL 加密连接——数据校验传输安全再升级
mysql
倔强的石头_2 天前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测
数据库