• 面试官:MySQL双主架构有什么优缺点?

面试官:MySQL双主架构有什么优缺点?

2025-05-14 11:37:03 栏目:宝塔面板 394 阅读

大家好,我是君哥。

双主架构是 MySQL 常见的一种架构模式,它的特点是有两个主节点对外提供服务,并且这两个主节点互为主备。今天来学习一下双主架构。

1.双主复制

这种架构的特点配置两个主库,每个主库都提供读写服务,并且这两个主库互为主备。如下图:

在 M1 写入的数据要同步到 M2,在 M2 写入的数据要同步到 M1。这种两个主库同时支持写入,这种架构模式一个明显的优势写入效率高。比如一个应用在不同的城市部署了两个主节点,请求可以就近选择写入数据库。

但这种架构在数据同步时很容易出问题。

案例一:M1 和 M2 同时收到一张表的插入请求,这张表是自增主键,两张表插入后主键相同。这时发生数据同步,这条插入语句在 binlog 里面记录的是 row 格式,同步时发生主键冲突。

MySQL binlog 有三种格式:

  • STATEMENT:记录的是 SQL 语句本身;
  • ROW:记录的是数据的变化;
  • MIXED:STATEMENT 和 ROW 格式的结合,MySQL 会根据 SQL 语句特性选择使用 STATEMENT 还是 ROW 格式。

MySQL 5.0 后可以通过设置 auto_increment_increment 和 auto_increment_offset 这两个选项来解决这个问题。

案例二:在 M1 上执行了一条语句,生成 binlog 后发给 M2 进行同步,M2 执行完成后又生成 binlog 同步给 A,导致一条语句循环复制。

这个问题的解决方法是要求 M1 和 M2 的 server id不相同,M1 产生的 binlog 记录 server id 是 M1,M2 执行同步时生成的 binlog 也记录 server id 为 M1。这样同步给 M1 是,M1 判断到 server id 跟自己相同,就丢弃这个日志,不做同步。

案例三:同步过程中会有数据不一致的问题。比如用户 xiaoming 的账户余额是 100。M1 执行了 update 操作把账户余额更新成 150,M2 执行了 update 操作更新成 130。

解决这种数据不一致问题的一个思路是严格划分数据和设置权限,比如案例中小明的所有数据只能在 M1 上操作。

案例四:因为节点发生故障,M1 不能复制了,但是应用可以写数据库,M2 能正常写和复制,这个问题就很难解决了。

解决这个问题,需要给 M1 和 M2 配置从节点,主节点故障后切换到从节点进行工作。

2.主备复制

这个架构模式的特点是双主节点中,同一时刻只有一个主节点提供写服务,另一个主节点只能提供读服务。如下图:

这个架构相当于比单主节点架构多了一个热备,有如下优势:

  • 因为 M1 和 M2 配置对称,切换主备比较容易;
  • 有助于故障转移和恢复;
  • 可以在不影响应用的情况下进行数据库升级和维护;
  • 不用考虑循环复制问题和主备不一致问题。

当然,主备架构也有缺点,那就是写性能不能得到提升。

3.主主架构拥有备库

主主架构中每个主库也可以拥有备库,如下图:

这种配置为每个主库增加了一个备份,可以防止单点故障,同时备库也可以处理读请求,提高数据库整体读效率。

这个架构的缺点是增加了机器成本。

4.环形复制

环形复制架构是 MySQL 集群中拥有多个主库,主库之间形成一个环形,前面一个节点是当前节点的主库,当前节点是前面节点的备库,也是后面一个节点的主库。如下图:

环形复制这种架构其实并不推荐,因为它很难做到故障转移,高可用特性依赖于每个节点不出故障。但是如果一个节点出了故障,去掉这个节点,这个节点产生的 binlog 将一直循环复制下去,因为只有通过这个节点的 server id 才能做出判断停止复制。

5.总结

本文介绍了 MySQL 双主架构的多种复制架构,双主架构需要注意解决循环复制、单点故障问题,同时做好数据权限划分。

本文地址:https://www.yitenyun.com/209.html

搜索文章

Tags

数据库 API FastAPI Calcite 电商系统 MySQL Web 应用 异步数据库 数据同步 ACK 双主架构 循环复制 TIME_WAIT 运维 负载均衡 服务器 管理口 HexHub Docker JumpServer SSL 堡垒机 跳板机 HTTPS 服务器性能 JumpServer安装 堡垒机安装 Linux安装JumpServer SQL 查询 生命周期 Deepseek 宝塔面板 Linux宝塔 锁机制 esxi esxi6 root密码不对 无法登录 web无法登录 行业 趋势 序列 核心机制 Windows Windows server net3.5 .NET 安装出错 HTTPS加密 开源 PostgreSQL 存储引擎 宝塔面板打不开 宝塔面板无法访问 Windows宝塔 Mysql重置密码 机器学习 Redis 查看硬件 Linux查看硬件 Linux查看CPU Linux查看内存 Undo Log 机制 响应模型 Spring 动态查询 Oracle 处理机制 InnoDB 数据库锁 优化 万能公式 连接控制 group by 索引 Serverless 无服务器 语言 监控 无法访问宝塔面板 异步化 ES 协同 技术 工具 openHalo scp Linux的scp怎么用 scp上传 scp下载 scp命令 Postgres OTel Iceberg 缓存方案 缓存架构 缓存穿透 国产数据库 高可用 分页查询 数据 主库 SVM Embedding Linux 安全 Netstat Linux 服务器 端口 存储 SQLite-Web SQLite 数据库管理工具 GreatSQL 连接数 加密 场景 云原生 R edis 线程 防火墙 黑客 启动故障 Recursive R2DBC 向量数据库 大模型 共享锁 SQLark 日志文件 MIXED 3 OB 单机版 ​Redis 推荐模型 Canal AI 助手 RocketMQ 长轮询 配置 自定义序列化 PG DBA 不宕机 信息化 智能运维 业务 Python 传统数据库 向量化 向量库 Milvus Ftp 同城 双活 聚簇 非聚簇 线上 库存 预扣 修改DNS Centos7如何修改DNS IT运维 Hash 字段 Web 接口 开发 架构 电商 系统 filelock 分库 分表 Rsync 数据类型 磁盘架构 MySQL 9.3 缓存 MongoDB 数据结构 redo log 重做日志 数据分类 MCP 开放协议 sftp 服务器 参数 mini-redis INCR指令 语句 PostGIS • 索引 • 数据库 ZODB Doris SeaTunnel 流量 分布式架构 分布式锁​ 窗口 函数 频繁 Codis MVCC Go 数据库迁移 数据备份 虚拟服务器 虚拟机 内存 失效 工具链 人工智能 推荐系统 EasyExcel MySQL8 主从复制 代理 prometheus Alert Redisson 锁芯 MGR 分布式集群 分页 千万级 大表 高效统计 今天这篇文章就跟大家 播客 StarRocks 数据仓库 网络架构 网络配置 引擎 性能 网络故障 聚簇索引 非聚簇索引 事务 Java 数据集成工具 发件箱模式 INSERT 崖山 新版本 COMPACT 核心架构 订阅机制 QPS 高并发 Entity Redka 容器 Weaviate RDB AOF SSH 关系数据库 Web B+Tree ID 字段 数据页 速度 服务器中毒 Caffeine CP 数据脱敏 加密算法 Redis 8.0 Valkey Valkey8.0 DBMS 管理系统 分布式 集中式 OAuth2 Token 自动重启 容器化 SpringAI 微软 SQL Server AI功能 读写 LRU 模型 原子性 排行榜 排序 数据字典 兼容性 池化技术 连接池 JOIN 意向锁 记录锁 事务隔离 业务场景 Testcloud 云端自动化 单点故障 UUID ID dbt 数据转换工具 分页方案 排版 日志 部署 1 ReadView 优化器 InfluxDB 悲观锁 乐观锁 Pottery 事务同步 网络 sqlmock 分布式锁 Zookeeper UUIDv7 主键 AIOPS 对象 双引擎 产业链 编程 仪表盘 RAG HelixDB Ansible Pump Order 单线程 字典 恢复数据 拦截器 动态代理 Crash 代码 线程安全 国产 用户 快照读 当前读 视图 LLM IT 订单 List 类型 慢SQL优化 count(*) count(主键) 行数 RR 互联网 表空间 解锁 调优 Next-Key 神经系统 CAS 矢量存储 数据库类型 AI代理 多线程 查询规划 GitHub Git 算法 技巧 并发控制 恢复机制 闪回