0

0

mysql并发读多写少如何优化_mysql架构设计思路

P粉602998670

P粉602998670

发布时间:2025-12-29 18:26:03

|

171人浏览过

|

来源于php中文网

原创

不是必须但几乎总是值得做;读远超写时主库易因SELECT压力过载,主从分离可释放主库压力,前提是从库能接受几秒延迟且应用层正确路由读写。

mysql并发读多写少如何优化_mysql架构设计思路

读多写少时,MySQL 主从分离是不是必须的?

不是必须,但几乎总是值得做。当读请求远超写请求(比如 9:1),单点 MySQL 很快会因 SELECT 压力导致连接堆积、CPU 升高、复制延迟加剧。主从分离能立刻释放主库压力,让 INSERT/UPDATE/DELETE 更专注、更稳定。

关键判断点:只读从库是否能接受几秒级延迟? 如果业务允许(如商品列表、用户资料页、后台报表),就适合;如果要求强一致性(如余额查询后立即下单),就得搭配 SELECT ... FOR UPDATE 或强制走主库逻辑。

  • 从库至少部署 1 台,建议用 read_only=ON + super_read_only=ON 防误写
  • 应用层路由要明确:写操作固定打到主库地址,读操作按策略分发(轮询、权重、或基于事务上下文判断)
  • 避免在从库执行 LOAD DATA INFILECREATE TEMPORARY TABLE 等不被复制的操作,否则可能引发 Slave_SQL_Running: No

索引优化比加机器更有效,但哪些字段该建联合索引?

读多场景下,慢查询往往集中在几个高频 WHERE + ORDER BY + LIMIT 组合。联合索引不是“把所有 WHERE 字段堆一起”,而是按 WHERE = 条件 → WHERE IN/范围 → ORDER BY → SELECT 列 的顺序组织。

例如常见查询:SELECT id, title FROM article WHERE status = 1 AND category_id = 123 ORDER BY created_at DESC LIMIT 20。最优索引是:INDEX(status, category_id, created_at) —— 注意 created_at 必须是 DESC 方向(MySQL 8.0+ 支持显式 DESC,5.7 及以前默认升序,逆序扫描效率低)。

  • 避免对 TEXTBLOB 字段建索引;大字段用前缀索引要谨慎,SELECT ... LIKE '%xxx' 无法用上索引
  • 定期用 pt-query-digest 分析慢日志,重点关注 Rows_examined 远大于 Rows_sent 的查询
  • 删除长期未命中的索引(通过 sys.schema_unused_indexesperformance_schema.table_io_waits_summary_by_index_usage

连接池和查询缓存要不要开?

MySQL 8.0 已彻底移除 query_cache_type,别再配它。而连接池必须由应用层控制,MySQL 自身没有“连接池”概念 —— 它只有 max_connections 上限,超了直接报 Too many connections

蛙蛙写作
蛙蛙写作

超级AI智能写作助手

下载

真实瓶颈常出现在应用频繁创建/销毁连接,而非 MySQL 处理不过来。Java 用 HikariCP、Go 用 database/sql 自带池、Python 用 SQLAlchemyQueuePool,都要设合理 max_pool_size(通常 20–50,视并发量调)和 idle_timeout(避免空闲连接占着 wait_timeout 不放)。

  • 不要把 max_connections 设得过大(如 2000+),会导致内存暴涨、上下文切换严重
  • 监控 Threads_connectedThreads_running,后者持续 > 30 就说明有慢查询或锁等待在积压
  • 短连接场景(如 PHP-FPM 模式)可考虑 mysqlnd_ms 或代理层(ProxySQL)做连接复用

分库分表是不是现在就要做?

不是。95% 的读多写少系统,靠主从 + 索引 + 连接池 + 合理缓存(Redis)就能撑到千万级日活。过早分库分表只会让事务、跨库 JOIN、数据迁移、运维复杂度指数上升。

真正该启动分片的信号是:单表超过 2000 万行且 ALTER TABLE 已无法在线完成,或主从延迟稳定在 60s 以上且无法通过降读、拆查询解决。此时优先考虑垂直拆分(如把日志表、统计表独立出主库),再评估水平分片。

  • 分片键必须是高频查询的等值条件字段(如 user_id),不能是 create_time 这类范围字段
  • 避免跨分片 ORDER BY ... LIMIT,它需要归并排序,性能陡降
  • ShardingSphere-ProxyVitess 比硬编码分片逻辑更可控,但依然绕不开分布式事务的妥协(最终一致性 or TCC)

最常被忽略的一点:缓存穿透和雪崩问题在读多场景下爆发更快。哪怕加了 Redis,也要给空结果设短 TTL,并用 SETNX 配合本地锁防击穿 —— 这比调优 MySQL 本身还关键。

相关专题

更多
python开发工具
python开发工具

php中文网为大家提供各种python开发工具,好的开发工具,可帮助开发者攻克编程学习中的基础障碍,理解每一行源代码在程序执行时在计算机中的过程。php中文网还为大家带来python相关课程以及相关文章等内容,供大家免费下载使用。

711

2023.06.15

python打包成可执行文件
python打包成可执行文件

本专题为大家带来python打包成可执行文件相关的文章,大家可以免费的下载体验。

625

2023.07.20

python能做什么
python能做什么

python能做的有:可用于开发基于控制台的应用程序、多媒体部分开发、用于开发基于Web的应用程序、使用python处理数据、系统编程等等。本专题为大家提供python相关的各种文章、以及下载和课程。

737

2023.07.25

format在python中的用法
format在python中的用法

Python中的format是一种字符串格式化方法,用于将变量或值插入到字符串中的占位符位置。通过format方法,我们可以动态地构建字符串,使其包含不同值。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

617

2023.07.31

python教程
python教程

Python已成为一门网红语言,即使是在非编程开发者当中,也掀起了一股学习的热潮。本专题为大家带来python教程的相关文章,大家可以免费体验学习。

1235

2023.08.03

python环境变量的配置
python环境变量的配置

Python是一种流行的编程语言,被广泛用于软件开发、数据分析和科学计算等领域。在安装Python之后,我们需要配置环境变量,以便在任何位置都能够访问Python的可执行文件。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.08.04

python eval
python eval

eval函数是Python中一个非常强大的函数,它可以将字符串作为Python代码进行执行,实现动态编程的效果。然而,由于其潜在的安全风险和性能问题,需要谨慎使用。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

573

2023.08.04

scratch和python区别
scratch和python区别

scratch和python的区别:1、scratch是一种专为初学者设计的图形化编程语言,python是一种文本编程语言;2、scratch使用的是基于积木的编程语法,python采用更加传统的文本编程语法等等。本专题为大家提供scratch和python相关的文章、下载、课程内容,供大家免费下载体验。

696

2023.08.11

俄罗斯搜索引擎Yandex最新官方入口网址
俄罗斯搜索引擎Yandex最新官方入口网址

Yandex官方入口网址是https://yandex.com;用户可通过网页端直连或移动端浏览器直接访问,无需登录即可使用搜索、图片、新闻、地图等全部基础功能,并支持多语种检索与静态资源精准筛选。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

1

2025.12.29

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.5万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 776人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号