当前位置: 首页 > article >正文

一文搞懂 MySQL 主从复制

目录一、什么是 MySQL 主从复制主从复制的核心作用我们为什么要用它二、主从复制的底层原理大白话拆解全流程先搞懂 2 个核心文件再认识 3 个关键线程完整同步流程一步一步讲明白步骤 1主库写数据记录 binlog步骤 2从库 IO 线程拉取主库的 binlog步骤 3从库 SQL 线程重放中继日志步骤 4同步完成主从数据一致补充binlog 的 3 种格式一、什么是 MySQL 主从复制简单说MySQL 主从复制就是让一台主数据库Master和一台 / 多台从数据库Slave建立自动的数据同步关系主库上所有的数据变更增删改都会实时、自动地同步到从库最终主从库的数据完全一致。你可以把它理解成主库 公司总部的官方文档库所有内容的修改、新增都只能在总部完成从库 各个分公司的文档副本总部的文档一更新副本就自动同步分公司只能查阅不能私自修改。主从复制的核心作用我们为什么要用它读写分离扛住高并发业务里 80% 的请求都是查询读只有 20% 是增删改写。我们可以让主库只处理写请求所有读请求都分给从库相当于把数据库压力分散到多台机器瞬间就能扛住几倍的访问量这是它最常用的场景。数据热备份不怕误操作主库数据实时同步到从库相当于有了一个实时热备份。就算你在主库误删了数据从库还有完整的副本能快速恢复不用再靠几天前的冷备份哭唧唧。高可用实现故障容灾如果主库突然宕机我们可以立刻把一台从库切换成新的主库业务直接连新主库不用等主库修复大大缩短业务停机时间。业务隔离不影响核心服务比如你要做数据分析、报表统计这些操作非常耗资源如果直接在主库跑可能会把主库卡崩。这时候你可以在从库上跑这些操作就算从库跑满了也完全不影响核心业务。二、主从复制的底层原理大白话拆解全流程很多人一听到主从复制的原理就被三个线程、binlog、中继日志劝退了其实特别简单整个过程就像「总部发文件分店同步执行」全程只有 2 个核心文件、3 个关键角色、4 个核心步骤。先搞懂 2 个核心文件binlog二进制日志只存在于主库是主库的「操作流水账」。主库上所有对数据有修改的 SQL增删改事务提交后都会按顺序写到 binlog 里它记录了每一次数据变更的完整信息。relay log中继日志只存在于从库是从库的「中转文件柜」专门用来存放从主库拉取过来的 binlog 内容。再认识 3 个关键线程整个复制过程全靠这 3 个线程配合完成缺一不可主库的Binlog Dump 线程从库的IO 线程从库的SQL 线程完整同步流程一步一步讲明白步骤 1主库写数据记录 binlog当我们在主库执行一条增删改 SQL事务提交的时候主库会先把这次数据变更的详细信息按时间顺序写到 binlog 文件里。就像总部修改了产品价格先把这次修改的内容按顺序写到《总部操作流水账》里。步骤 2从库 IO 线程拉取主库的 binlog从库会主动和主库建立 TCP 连接然后从库的 IO 线程会给主库的 Binlog Dump 线程发请求「把你 binlog 里位置 xxx 之后的新内容发给我」。主库的 Binlog Dump 线程收到请求后会把 binlog 里对应的内容源源不断地发给从库的 IO 线程。从库的 IO 线程收到内容后不会直接修改数据而是先把它写到本地的 relay log中继日志里。就像分店的对接员找总部的快递员要最新的流水账快递员把文件发过来对接员收到后先放到店里的中转柜不直接改货架。步骤 3从库 SQL 线程重放中继日志从库的 SQL 线程会实时监控中继日志一旦发现中继日志里有新内容就会立刻把里面的操作在从库上完整地执行一遍。就像分店的理货员从中转柜拿出流水账照着上面的操作在店里的货架上同步修改价格、上下架商品保证分店和总部的货架完全一致。步骤 4同步完成主从数据一致当 SQL 线程执行完中继日志里的所有操作后从库的数据就和主库完全一致了。整个过程会不断循环主库一有新的变更就会自动同步到从库实现实时同步。补充一个关键点默认的主从复制是异步的。主库只要把 binlog 写好就会给客户端返回成功不会等从库同步完成。这也是主从延迟问题的根源后面会详细讲。补充binlog 的 3 种格式binlog 有 3 种记录格式直接决定了同步的稳定性STATEMENT语句级记录你执行的 SQL 语句本身。优点是日志体积小缺点是NOW()、UUID()这类函数会导致主从数据不一致现在基本不用了。ROW行级记录「哪一行的数据被改成了什么样子」不记录 SQL 语句。优点是绝对不会出现数据不一致稳定性拉满缺点是日志体积稍大。这是 MySQL 默认格式也是生产环境首选。MIXED混合模式上面两种的结合MySQL 自动判断用哪种格式一般不推荐。

相关文章:

一文搞懂 MySQL 主从复制

目录 一、什么是 MySQL 主从复制? 主从复制的核心作用(我们为什么要用它?) 二、主从复制的底层原理:大白话拆解全流程 先搞懂 2 个核心文件 再认识 3 个关键线程 完整同步流程,一步一步讲明白 步骤 …...

macos简单配置openclaw贝

1 实用案例 1.1 表格样式生成 本示例用于生成包含富文本样式与单元格背景色的Word表格文档。 模板内容: 渲染代码: # python-docx-template/blob/master/tests/comments.py from docxtpl import DocxTemplate, RichText # data: python-docx-template/bl…...

【MATLAB源码-第415期】基于MATLAB的等效电路与电热耦合的锂离子电池CC-CV充电控制、SOC估计及BMS保护与故障诊断仿真

操作环境:MATLAB 2024a1、算法描述基于等效电路与电热耦合的锂离子电池CC-CV充电控制及BMS保护仿真研究摘要锂离子电池作为电动汽车、储能系统与便携式电子设备中的核心储能单元,其充电过程不仅关系到能量补给效率,还直接影响安全性、寿命保持…...

营销自动化数据驱动 - 多源数据 OLAP 架构演进嘉

1. 流图:数据的河流 如果把传统的堆叠面积图想象成一块块整齐堆叠的积木,那么流图就像一条蜿蜒流淌的河流,河道的宽窄变化自然流畅,波峰波谷过渡平滑。 它特别适合展示多个类别数据随时间的变化趋势,尤其是当你想强调整…...

硬件笔记——使用OrCAD绘制原理图

一、新建工程新建工程,并输入工程的名称和路径,然后会弹出一个PAGE页面:二、修改PAGE页面大小有几种尺寸规格,也可以自定义尺寸,这里以尺寸B规格为例:三、添加原理图库到工程里点击工具栏右上角的芯片图标&…...

Burpsuite之暴力破解+验证码识别 | 添柴不加火萍

springboot自动配置 自动配置了大量组件,配置信息可以在application.properties文件中修改。 当添加了特定的Starter POM后,springboot会根据类路径上的jar包来自动配置bean(比如:springboot发现类路径上的MyBatis相关类&#xff…...

8250串行通信避坑指南:如何用内环测试快速定位硬件故障(附Proteus仿真文件)

8250串行通信避坑指南:如何用内环测试快速定位硬件故障 在嵌入式系统开发中,串行通信故障排查往往是最令人头疼的问题之一。当你面对一个无法正常通信的系统时,问题可能出在硬件连接、芯片配置、软件逻辑或者中断处理等任何一个环节。而8250这…...

RIT库:ARM Cortex-M高精度周期性中断定时器实现

1. RIT库概述:嵌入式系统中的高精度周期性中断定时器实现RIT(Repetitive Interrupt Timer)库是一个专为ARM Cortex-M系列微控制器设计的轻量级、高精度周期性中断定时器抽象层。其核心目标并非替代硬件外设本身,而是提供一套统一、…...

SPI协议实战指南:从基础配置到多设备高效通信

1. SPI协议基础:从零开始理解通信机制 第一次接触SPI协议时,我被它那看似简单的四线制结构迷惑了——明明只有四条线,为什么能实现高速全双工通信?后来在调试智能家居主控板时才发现,正是这种精简设计让SPI成为嵌入式领…...

基于深度学习的CMIP6超分辨率气候数据降尺度技术:中国10公里逐日气象与PET估算实践

1. 为什么我们需要10公里分辨率的气候数据? 想象一下你正在用手机查看天气预报,如果预报只能告诉你"整个华北地区明天有雨",但无法精确到北京海淀区是否下雨,这样的信息对你规划出行有多大帮助?这就是传统气…...

告别虚拟机!在WSL2的Ubuntu 20.04上搞定OpenCV 4.5+完整开发环境(含GUI显示配置)

在WSL2的Ubuntu 20.04上构建OpenCV 4.5全功能开发环境 当计算机视觉开发者第一次尝试在Windows系统上搭建OpenCV环境时,往往会面临两个选择:要么忍受虚拟机沉重的性能开销,要么在原生Windows环境中与各种兼容性问题搏斗。而今天,我…...

DoubleResetDetector_Generic:嵌入式双复位检测库技术解析

1. DoubleResetDetector_Generic 库深度技术解析:跨平台双复位检测的工程实现1.1 工程需求与设计动机在嵌入式设备的生命周期管理中,“如何安全、可靠地进入配置模式”是一个被反复验证却始终缺乏标准化解法的核心问题。传统方案如物理按键、专用跳线或串…...

分享一下我面试Agent岗位时被问到的问题……

以下是我面试了几家公司后,整理出来HR的高频提问总结。 1. 你们用的 Agent 框架是什么?ReAct 还是 Plan-and-Execute? 我:我们主要用 ReAct,就是边想边干的那种。模型每走一步看一眼结果再决定下一步,灵活…...

Modbus协议避坑指南:功能码06写入失败的5个常见原因及解决方法(附Wireshark抓包分析)

Modbus协议避坑指南:功能码06写入失败的5个常见原因及解决方法(附Wireshark抓包分析) 在工业自动化领域,Modbus协议因其简单可靠的特点,成为设备通信的基石。而功能码06(写单个寄存器)作为最常用…...

程序行为的构成:规则、数据与延迟固化的艺术

程序行为的构成:规则、数据与延迟固化的艺术 2026-04-08 程序行为的构成:规则、数据与延迟固化的艺术 在软件系统中,程序行为并非凭空产生,而是规则作用于数据所产生的可观察效应。这一基本公式将程序的内在逻辑清晰地分为两个部分…...

计算机毕业设计:Python气象数据可视化与采集管理系统 Flask框架 数据分析 可视化 爬虫 气象数据分析(建议收藏)✅

博主介绍:✌全网粉丝50W,前互联网大厂软件研发、集结硕博英豪成立软件开发工作室,专注于计算机相关专业项目实战6年之久,累计开发项目作品上万套。凭借丰富的经验与专业实力,已帮助成千上万的学生顺利毕业,…...

【限时开源】:我们刚交付的三级医院FHIR适配引擎源码(C#/.NET 6+),含动态Profile加载、术语服务桥接、差量同步模块——仅开放72小时

第一章:FHIR适配引擎在三级医院信息系统的战略定位与开源意义FHIR适配引擎并非简单的协议转换中间件,而是三级医院实现跨系统互操作、支撑国家健康医疗大数据平台对接、满足《医疗卫生机构网络安全管理办法》与《电子病历系统功能应用水平分级评价标准》…...

嵌入式程序main()退出处理机制与优化实践

1. 嵌入式程序执行的生命周期解析在裸机嵌入式开发中,程序执行流程与通用计算机存在本质差异。以8051架构为例,当开发者在Keil环境下编写一个简单的LED控制程序时,完整的执行链条包含以下几个关键阶段:硬件复位阶段(0x…...

OpenClaw飞书机器人配置:SecGPT-14B安全警报实时推送

OpenClaw飞书机器人配置:SecGPT-14B安全警报实时推送 1. 为什么需要安全警报实时推送? 上周三凌晨3点,我的个人服务器突然收到异常登录告警。当我早上看到邮件时,攻击者早已完成数据窃取并抹除了痕迹。这次事件让我意识到&#…...

嵌入式贝叶斯优化:Arduino/ESP32轻量级1D黑箱调参库

1. 项目概述Bayesian Optimization(贝叶斯优化)Arduino 库是一个面向资源受限嵌入式平台的轻量级、确定性、单输入维度(1D)黑箱函数优化器。它并非通用数值计算库,而是专为微控制器场景深度定制的实时决策引擎——当目…...

CAN总线数字信号特性与抗干扰技术解析

1. CAN总线信号本质解析CAN总线采用数字信号传输机制,这一点可以从其物理层特性得到明确验证。在CAN总线的差分信号线上,实际传输的是经过编码的数字电平信号(显性电平与隐性电平),而非连续变化的模拟电压。这种设计从…...

中国婴幼儿肌肤特点分析报告

中国婴幼儿肌肤受基因、气候、生活习惯等多重因素影响,呈现出屏障先天薄弱、结构发育缓慢、耐受力偏低等独特生理特征,再加上国内气候多样、高频清洁习惯、西方育儿理念本土化不足等后天因素,使得中国宝宝更易出现干燥、敏感、热疹、湿疹等问…...

电源防反接方案设计与工程实践

1. 电源反接的危害与防护必要性在工业控制、自动化设备等需要手动接线的应用场景中,电源反接是最常见的人为操作失误之一。我曾参与过一个工业PLC控制柜项目,现场工程师在调试时不慎将24V电源极性接反,导致价值上万元的控制模块瞬间烧毁。这种…...

边缘设备资源告急?立刻启用.NET 9的Dynamic PGO+Crossgen2预编译组合技(仅限Preview 5+)

第一章:边缘设备资源告急?立刻启用.NET 9的Dynamic PGOCrossgen2预编译组合技(仅限Preview 5)在资源受限的边缘设备(如Raspberry Pi 4、Jetson Nano或工业PLC网关)上,.NET应用常因JIT编译开销与…...

OpenClaw合规审计:用SecGPT-14B自动检查等保2.0要求

OpenClaw合规审计:用SecGPT-14B自动检查等保2.0要求 1. 为什么需要自动化合规审计 去年参与某金融科技项目时,我深刻体会到传统合规审计的痛点。团队花了整整三周时间手工核对服务器配置、整理证据材料,最终交付的等保2.0自查报告仍被指出存…...

【FastAPI 2.0流式AI响应终极指南】:零配置实现毫秒级SSE/Chunked异步响应,附官方插件源码级安装手册

第一章:FastAPI 2.0 异步 AI 流式响应插件概述FastAPI 2.0 原生强化了对异步流式响应(StreamingResponse)的底层支持,为大语言模型(LLM)推理、语音合成、实时数据生成等典型 AI 场景提供了低延迟、高并发的…...

WS2812嵌入式驱动:高精度时序与柔性硬件协同设计

1. WS2812驱动库深度解析:面向智能LED夹克的嵌入式底层实现1.1 技术定位与工程需求溯源WS2812并非一个抽象的“库”,而是一类集成控制电路与RGB LED于一体的智能发光单元。其核心价值在于将传统LED驱动中复杂的时序控制、电平转换、电流调节等模拟电路功…...

C# 面试高频题:装箱和拆箱是如何影响性能的?彝

OCP原则 ocp指开闭原则,对扩展开放,对修改关闭。是七大原则中最基本的一个原则。 依赖倒置原则(DIP) 什么是依赖倒置原则 核心是面向接口编程、面向抽象编程, 不是面向具体编程。 依赖倒置原则的目的 降低耦合度&#…...

保姆级教程:手把手教你将中国土地利用栅格数据(GRID/TIFF)转换成WRF能用的二进制格式(含GDAL和index文件配置避坑指南)

从GRID到二进制:WRF土地利用数据转换全流程实战指南 当你在深夜盯着屏幕,反复检查那些令人头疼的GDAL命令和index文件参数时,是否曾希望有人能一步步带你走出这个迷宫?作为WRF模拟中最为基础却又最容易出错的环节,土地…...

Ego-Planner仿真不迷路:手把手教你配置PX4位姿真值话题与launch文件(附常见报错解决)

Ego-Planner仿真实战:PX4位姿真值配置与launch文件深度解析 在无人机自主导航领域,仿真环境搭建是算法验证的关键第一步。当你在Ego-Planner仿真中看到"找不到里程计"的红色报错时,那种挫败感我深有体会——明明Gazebo中的无人机模…...