0

0

mysql数据库的复制架构与主从同步机制

P粉602998670

P粉602998670

发布时间:2026-01-08 00:39:34

|

785人浏览过

|

来源于php中文网

原创

MySQL主从同步是基于binlog的异步/半同步复制机制,存在延迟与不一致风险;需配置ROW格式、监控IO/SQL线程状态、合理使用GTID及半同步以提升可靠性。

mysql数据库的复制架构与主从同步机制

MySQL 主从同步不是自动“实时一致”的管道,而是一套基于二进制日志(binlog)的异步/半同步复制机制;主库写入后,从库需拉取、重放日志才能追上——这意味着延迟、不一致窗口和潜在的数据断裂风险。

主从复制依赖 binlog 格式与执行模式

主库必须开启 binlog,且格式直接影响从库重放行为和一致性保障能力:

  • STATEMENT:记录 SQL 语句本身;在含 NOW()UUID()、用户变量等非确定性函数时,从库执行结果可能与主库不同
  • ROW:记录每行数据变更前后的镜像;安全但体积大,尤其批量更新时 binlog 膨胀明显
  • MIXED:默认混合模式,对非确定性语句自动切到 ROW;但无法完全规避判断盲区,生产环境建议显式设为 ROW

确认当前格式:

SHOW VARIABLES LIKE 'binlog_format';
修改需在主库配置文件中设置 binlog_format = ROW 并重启(或动态生效,取决于 MySQL 版本)。

从库 IO 线程与 SQL 线程分工明确,各自可能中断

复制由两个独立线程协作完成,故障点也分离:

  • IO_THREAD:连接主库,拉取 binlog 事件并写入本地 relay log;中断常见于网络超时、主库权限不足(如复制用户无 REPLICATION SLAVE 权限)、主库 binlog 被清理(expire_logs_days 过小)
  • SQL_THREAD:读取 relay log,逐条重放;中断多因语句冲突(如从库有同名表但结构不同)、DDL 与 DML 并发导致锁等待、或遇到 STOP SLAVE 后未手动恢复

检查状态用:

SHOW SLAVE STATUS\G
重点看 Slave_IO_RunningSlave_SQL_Running 是否均为 Yes,以及 Seconds_Behind_Master 是否持续增长。

GTID 模式能简化故障恢复,但要求全集群统一启用

传统基于文件名+位置(File/Position)的复制,在主库切换或从库异常后需要人工计算偏移量;GTID(Global Transaction Identifier)为每个事务分配唯一 ID,使从库可自动定位并跳过已执行事务:

阿里云-虚拟数字人
阿里云-虚拟数字人

阿里云-虚拟数字人是什么? ...

下载
  • 启用前需确保所有节点 gtid_mode = ONenforce_gtid_consistency = ON
  • 从库执行 CHANGE MASTER TO ... GTID_SET = ... 时,若 GTID_EXECUTED 不匹配,会报错 ERROR 1236 (HY000),此时需用 SET GLOBAL gtid_purged = '...' 手动补全(仅当确认缺失事务已丢失时才可操作)
  • GTID 下 RESET SLAVE 会清空 gtid_executed,务必搭配 RESET SLAVE ALL 避免后续启动失败

查看当前 GTID 状态:

SELECT @@global.gtid_mode, @@global.gtid_executed;

半同步复制不能消除延迟,只约束主库提交行为

启用 rpl_semi_sync_master_enabled 后,主库 COMMIT 将阻塞直到至少一个从库确认收到 binlog(而非执行完成),这能防止主库宕机后丢失已提交事务,但:

  • 仍不保证从库已重放,Seconds_Behind_Master 可能很大
  • 若所有半同步从库失联,主库会自动退化为异步模式(由 rpl_semi_sync_master_timeout 控制超时时间)
  • 性能敏感场景下,超时值设太小易频繁降级,设太大则拖慢主库响应

启用后验证:

SELECT plugin_name, plugin_status FROM information_schema.plugins WHERE plugin_name LIKE '%semi%';

真正难处理的是主库崩溃后如何选新主——GTID + MHA 或 Orchestrator 可自动完成,但切换过程中的脑裂、从库数据不完整、应用连接未及时刷新等问题,远比配置复制参数更消耗运维精力。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

676

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

320

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

346

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1093

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

356

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

674

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

571

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

412

2024.04.29

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

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

精品课程

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

共48课时 | 1.7万人学习

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

共3课时 | 0.3万人学习

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

共1课时 | 783人学习

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

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