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;
相关推荐
KaMeidebaby1 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
ECT-OS-JiuHuaShan1 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算
八月瓜科技1 小时前
用AI来省电?iOS26.5正式版全球推送:信号弱网双提升,AI省电模式上新
数据库·人工智能·科技·深度学习·机器人
天若有情6731 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
dhashdoia2 小时前
GPT-5.5 代码开发实战:Codex与Browser Use深度集成与星链4SAPI优化方案
java·数据库·人工智能·gpt·架构
qq_283720052 小时前
LangChain+FAISS 向量数据库搭建轻量化 RAG 应用
数据库·langchain·faiss
小徐学编程-zZ3 小时前
Test-mall--后端联调与启动
数据库
一写代码就开心3 小时前
redis-cli 客户端查询set集合里面的具体数据
数据库·redis·缓存