MySQL慢查询攻略

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
RDS MySQL Serverless 高可用系列,价值2615元额度,1个月
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 本文详细介绍了MySQL慢查询优化的全流程,从定位性能瓶颈到具体优化策略,再到高级调优与预防监控。首先通过开启慢查询日志和分析工具(如pt-query-digest)找到问题SQL,接着从索引优化(如最左前缀原则、覆盖索引)、SQL语句重构(如避免全表扫描)及EXPLAIN执行计划解析等方面进行核心优化。随后深入参数调优和架构升级,如调整innodb_buffer_pool_size、实施分库分表等。最后,通过实时监控工具(如PMM、Prometheus+Grafana)建立长效机制,并以电商订单查询为例,展示优化前后性能大幅提升的实战效果。

一、慢查询定位:找到性能瓶颈

1.1 开启慢查询日志

sql

代码解读

复制代码

-- 查看当前配置  
SHOW VARIABLES LIKE '%slow_query%';  

-- 动态开启(重启失效)  
SET GLOBAL slow_query_log = 'ON';  
SET GLOBAL long_query_time = 2;  -- 阈值设为2秒  
SET GLOBAL slow_query_log_file = '/var/log/mysql/slow.log';  

-- 永久生效(修改my.cnf)  
[mysqld]  
slow_query_log = 1  
slow_query_log_file = /var/log/mysql/slow.log  
long_query_time = 2  
log_queries_not_using_indexes = 1  -- 记录未走索引的查询  

1.2 分析工具推荐

工具 使用场景 命令示例
mysqldumpslow 官方自带,基础分析 mysqldumpslow -s t /path/to/slow.log
pt-query-digest 高级分析,生成详细报告 pt-query-digest slow.log > report.txt
Percona Toolkit 专业级分析,支持多维度统计 pt-query-digest --filter '$event->{arg} =~ m/SELECT/i' slow.log

二、核心优化策略:从SQL到架构

2.1 索引优化(90%的性能问题根源)

黄金法则

  • 最左前缀原则:联合索引按字段顺序匹配
  • 覆盖索引:SELECT字段全在索引中,避免回表
  • 索引选择性:区分度高的字段(如唯一ID)优先建索引

示例优化

sql

代码解读

复制代码

-- 优化前(全表扫描)  
SELECT * FROM orders WHERE status = 'paid' AND create_time > '2023-01-01';  

-- 添加联合索引  
ALTER TABLE orders ADD INDEX idx_status_time(status, create_time);  

-- 优化后(索引范围扫描)  
SELECT id, status, amount FROM orders   
WHERE status = 'paid' AND create_time > '2023-01-01';  

2.2 SQL语句重构

常见问题与解决方案

问题类型 优化方案 示例
大分页查询 使用WHERE替代LIMIT OFFSET WHERE id > 1000 LIMIT 10
隐式类型转换 保持字段与参数类型一致 WHERE phone = '13800138000'
不必要的排序 移除ORDER BY或添加索引 添加INDEX(create_time)
IN子查询 改用JOIN JOIN (SELECT id FROM ...) tmp

2.3 EXPLAIN执行计划解析

关键字段解读

sql

代码解读

复制代码

EXPLAIN SELECT * FROM users WHERE age > 20;  
字段 理想值 问题信号
type ref/range/index ALL(全表扫描)
key 使用索引名称 NULL(未用索引)
rows 扫描行数少 数值过大(如>10000)
Extra Using index Using filesort/Using temporary

三、高级调优:参数与架构升级

3.1 参数优化(my.cnf关键配置)

ini

代码解读

复制代码

[mysqld]  
# 缓冲池大小(通常设为物理内存的70%-80%)  
innodb_buffer_pool_size = 8G  

# 日志写入策略  
innodb_flush_log_at_trx_commit = 1  # 高安全要求  
innodb_flush_log_at_trx_commit = 2  # 高性能场景  

# 连接管理  
max_connections = 500  
thread_cache_size = 50  

3.2 架构升级方案

场景 解决方案 优势
单表数据量过大(>5000万) 分库分表(Sharding) 水平扩展,降低单表压力
高频复杂查询 读写分离(主从复制) 分散读压力
实时分析需求 使用列式存储(如ClickHouse) 提升聚合查询速度

四、预防与监控:建立长效机制

4.1 实时监控工具

  • Percona Monitoring and Management (PMM):监控慢查询、锁等待
  • Prometheus + Grafana:自定义指标可视化
  • MySQL Enterprise Monitor:官方企业级方案

4.2 自动化优化建议

sql

代码解读

复制代码

-- 使用内置诊断工具  
ANALYZE TABLE orders;  -- 更新统计信息  
OPTIMIZE TABLE logs;   -- 重建表(针对碎片化严重场景)  

-- 查询优化建议器  
SELECT * FROM sys.schema_index_statistics;  
SELECT * FROM sys.statements_with_full_table_scans;  

五、实战案例:电商订单查询优化

5.1 原始慢查询(执行时间3.2秒)

sql

代码解读

复制代码

SELECT * FROM orders  
WHERE user_id = 1001  
  AND status IN ('paid', 'shipped')  
ORDER BY create_time DESC  
LIMIT 0, 10;  

5.2 优化步骤

  1. 执行计划分析:发现type=ALL,未使用索引
  2. 创建覆盖索引

sql

  1. 代码解读
  2. 复制代码
ALTER TABLE orders ADD INDEX idx_user_status_time(user_id, status, create_time);  
  1. SQL改写

sql

  1. 代码解读
  2. 复制代码
SELECT id, user_id, status, amount, create_time  
FROM orders  
WHERE user_id = 1001  
  AND status IN ('paid', 'shipped')  
ORDER BY create_time DESC  
LIMIT 10;  
  1. 结果:执行时间降至28ms,提升115倍!

总结:MySQL慢查询优化需结合索引策略、SQL重构、参数调优三位一体。通过EXPLAIN分析执行计划,使用pt-query-digest定位问题查询,建立监控体系预防性能退化,方能实现数据库高效稳定运行。


转载来源:https://juejin.cn/post/7494558809231261748


相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
SQL 监控 关系型数据库
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
【MYSQL高级】Mysql找出执行慢的SQL【慢查询日志使用与分析】
3277 0
|
Java 微服务 Spring
@EnableDiscoveryClient注解的作用
@EnableDiscoveryClient注解的作用 @EnableDiscoveryClient 及@EnableEurekaClient 类似,都是将一个微服务注册到Eureka Server(或其他 服务发现组件,例如Zookeeper、Consul等)
1731 0
|
5月前
|
负载均衡 算法
架构学习:7种负载均衡算法策略
四层负载均衡包括数据链路层、网络层和应用层负载均衡。数据链路层通过修改MAC地址转发帧;网络层通过改变IP地址实现数据包转发;应用层有多种策略,如轮循、权重轮循、随机、权重随机、一致性哈希、响应速度和最少连接数均衡,确保请求合理分配到服务器,提升性能与稳定性。
885 11
架构学习:7种负载均衡算法策略
|
4月前
|
人工智能 运维 监控
2025年阿里云服务器配置选择全攻略:CPU、内存、带宽与系统盘详解
在2025年,阿里云服务器以高性能、灵活扩展和稳定服务助力数字化转型,提供轻量应用服务器、通用型g8i实例等多样化配置,满足个人博客至企业级业务需求。针对不同场景(如计算密集型、内存密集型),推荐相应实例类型与带宽规划,强调成本优化策略,包括包年包月节省成本、ESSD云盘选择及地域部署建议。文中还提及安全设置、监控备份的重要性,并指出未来可关注第九代实例g9i支持的新技术。整体而言,阿里云致力于帮助用户实现性能与成本的最优平衡。 以上简介共计238个字符。
|
消息中间件 NoSQL Java
2024年高频Java面试题集锦(含答案),让你的面试之路畅通无阻!
或许这份面试题还不足以囊括所有 Java 问题,但有了它,我相信你一定不会“败”的很惨,因为有了它,足以应对目前市面上绝大部分的 Java 面试了,因为这篇文章不论是从深度还是广度上来讲,都已经囊括了非常多的知识点了。
|
6月前
|
弹性计算 关系型数据库 数据库
自建数据库迁移到云数据库实操
本课程详细介绍了自建数据库迁移到阿里云RDS的实操步骤。主要内容包括:创建实例资源、安全设置、配置自建的MySQL数据库、数据库的迁移、从自建数据库切换到RDS以及清理资源。通过这些步骤,学员可以掌握如何将自建数据库安全、高效地迁移到云端,并确保应用的正常运行。
340 26
ly~
|
8月前
|
网络协议 应用服务中间件 Apache
如何在 DNS 记录中设置反向代理服务器?
要设置反向代理服务器,首先需安装配置软件(如 Nginx 或 Apache),并确保域名正确指向服务器 IP。接着,在 DNS 中设置 A 或 CNAME 记录,将域名指向反向代理服务器。然后编辑 Nginx 或 Apache 的配置文件,将请求转发至后端服务器。最后,通过浏览器访问域名测试配置是否成功,并使用工具检查请求流向和响应情况。
ly~
761 3
|
9月前
|
前端开发
React按需加载antd步骤以及出现的问题
在使用`babel-plugin-import`插件时,可以在项目的根目录创建`.babelrc`文件或在`package.json`中添加babel配置。这两个文件中不应该存在重复的配置。如果出现"Multiple configuration files found"错误,需要选择其中一个文件进行配置,并删除另一个文件中的babel配置。使用该插件后,可以直接从`antd`引入组件,无需手动引入样式文件。
185 1
|
11月前
|
SQL 监控 数据库
MSSQL性能调优实战:索引策略优化、SQL查询重写与高效并发管理的具体技巧
在Microsoft SQL Server(MSSQL)的性能调优过程中,索引策略的优化、SQL查询的重写以及高效并发管理是关键环节
|
12月前
|
Dart 测试技术 开发工具
Dart开发环境搭建-Windows
Dart开发环境搭建-Windows
231 7