MySQL主从复制与读写分离

一、MySQL 主从复制

1. 核心概念

MySQL 主从复制是一种数据同步机制,通过配置将一台 MySQL 服务器(主库,Master)的数据变更实时同步到一台或多台 MySQL 服务器(从库,Slave)。

2. 核心价值
  • 数据热备:从库作为主库的实时副本,用于数据备份与灾难恢复。
  • 读写分离基础:为读写分离提供架构支撑,分散数据库压力。
  • 故障转移:主库故障时,可快速将从库提升为主库,保障业务连续性。
  • 负载分担:从库可独立承担数据分析、报表查询等离线任务。
3. 核心原理(异步复制)

主从复制基于 MySQL 的 Binlog(二进制日志) 实现,核心流程分为 3 步:

  1. 主库记录 Binlog:主库执行完写操作(增删改)后,将变更记录写入 Binlog 日志。
  2. 从库拉取 Binlog:从库的 I/O 线程连接主库,请求拉取指定位置的 Binlog,写入本地的 Relay Log(中继日志)。
  3. 从库重放 Relay Log:从库的 SQL 线程读取并执行 Relay Log 中的变更,将数据同步到本地。
4. 常见架构模式
  • 一主一从:最简单的架构,适用于数据备份、小规模读写分离。
  • 一主多从:最常用的架构,通过多个从库分担读压力,适用于读多写少的场景。
  • 双主架构:两台服务器互为主从,均支持写操作,需注意数据冲突问题。

二、MySQL 读写分离

1. 核心概念

读写分离是指将读请求和写请求分发到不同的数据库服务器

  • 写请求:仅发送给主库(Master),保证数据一致性。
  • 读请求:发送给从库(Slave),利用从库分担主库的读压力。
2. 核心价值
  • 提升并发能力:通过多个从库并行处理读请求,大幅提升系统的读吞吐量。
  • 保护主库:将大量读请求分流,避免主库因压力过大导致性能下降或宕机。
3. 主流实现方式
(1)应用层实现(代码层面)
  • 原理:在业务代码中通过逻辑判断,将读写请求分别连接主库和从库。
  • 代表工具:ShardingSphere-JDBC、Spring Boot + Dynamic DataSource。
  • 优缺点:无需额外部署中间件,性能损耗小;但代码侵入性强,扩容需修改代码。
(2)中间件层实现(代理模式)
  • 原理:在应用和数据库之间部署一层代理服务器,应用统一连接代理,由代理负责路由读写请求。
  • 代表工具
    • Mycat:国产开源中间件,支持分库分表 + 读写分离,配置简单,适合中小企业(你正在部署的 Mycat 即为此类)。
    • ShardingSphere-Proxy:Apache 顶级项目,功能全面,支持跨数据库。
    • ProxySQL:高性能 MySQL 代理,侧重流量控制与故障转移。
  • 优缺点:对业务代码无侵入,扩容灵活;但需额外维护中间件,有轻微性能损耗。

三、关键问题与解决方案

1. 主从延迟(最核心问题)
  • 现象:主库写入数据后,从库需要一定时间才能同步完成,导致从库读取到 "旧数据"。
  • 产生原因
    • 从库的 SQL 线程是单线程重放,若主库并发写压力大,从库同步速度跟不上。
    • 网络延迟、从库硬件性能弱于主库。
  • 缓解方案
    • 架构优化:采用半同步复制(保证至少一个从库收到 Binlog)或组复制(MGR)。
    • 业务优化:对实时性要求高的读请求(如 "下单后立即查询订单")强制走主库。
    • 监控告警:通过 SHOW SLAVE STATUS 监控延迟时间,设置阈值告警。
2. 数据一致性保障
  • 读写分离架构下,需优先保证 "写后读" 的一致性,常见策略:
    1. 关键业务强制读主:如用户登录、支付、订单查询等核心场景,直接连接主库。
    2. 延迟判断路由:中间件判断从库延迟时间,若延迟过高,自动切回主库。
    3. 会话级路由:同一用户的写操作后,后续一段时间内的读操作均路由到主库。
相关推荐
herinspace6 分钟前
管家婆实用贴-如何分离和附加数据库
开发语言·前端·javascript·数据库·语音识别
步辞1 小时前
Go语言怎么用channel做信号通知_Go语言channel信号模式教程【完整】
jvm·数据库·python
weixin_424999361 小时前
mysql行级锁失效的原因排查_检查查询条件与执行计划
jvm·数据库·python
Polar__Star1 小时前
uni-app怎么实现App端一键换肤 uni-app全局样式动态切换【实战】
jvm·数据库·python
南境十里·墨染春水2 小时前
linux学习进展 进程间通讯——共享内存
linux·数据库·学习
LinuxGeek10242 小时前
Kylin-Server-V11、openEuler-22.03和openEuler-24.03的MySQL 9.7.0版本正式发布
大数据·mysql·kylin
斯维赤3 小时前
Python学习超简单第八弹:连接Mysql数据库
数据库·python·学习
Chuer_3 小时前
讲透财务Agent核心概念,深度拆解财务Agent应用趋势
大数据·数据库·安全·数据分析·甘特图
gushinghsjj3 小时前
什么是主数据管理平台?怎么构建主数据管理平台?
大数据·数据库
Generalzy3 小时前
TinyDB轻量文档数据库
数据库