位置: 编程技术 - 正文

Mysql主从同步的实现原理

编辑:rootadmin

推荐整理分享Mysql主从同步的实现原理,希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:,内容如对您有帮助,希望把文章链接给更多的朋友!

1、什么是mysql主从同步?

当master(主)库的数据发生变化的时候,变化会实时的同步到slave(从)库。

2、主从同步有什么好处?

水平扩展数据库的负载能力。 容错,高可用。Failover(失败切换)/High Availability 数据备份。

3、主从同步的原理是什么?

首先我们来了解master-slave的体系结构。

如下图:

不管是delete、update、insert,还是创建函数、存储过程,所有的操作都在master上。当master有操作的时候,slave会快速的接收到这些操作,从而做同步。

但是,这个机制是怎么实现的呢?

在master机器上,主从同步事件会被写到特殊的log文件中(binary-log);在slave机器上,slave读取主从同步事件,并根据读取的事件变化,在slave库上做相应的更改。

如此,就实现了主从同步了!

下面我们来详细的了解。

3.1主从同步事件有哪些

上面说到:

Mysql主从同步的实现原理

在master机器上,主从同步事件会被写到特殊的log文件中(binary-log);

主从同步事件有3种形式:statement、row、mixed。

statement:会将对数据库操作的sql语句写入到binlog中。 row:会将每一条数据的变化写入到binlog中。 mixed:statement与row的混合。Mysql决定什么时候写statement格式的,什么时候写row格式的binlog。

3.2在master机器上的操作

当master上的数据发生改变的时候,该事件(insert、update、delete)变化会按照顺序写入到binlog中。

binlog dump线程

当slave连接到master的时候,master机器会为slave开启binlog dump线程。当master 的 binlog发生变化的时候,binlog dump线程会通知slave,并将相应的binlog内容发送给slave。

3.3在slave机器上的操作

当主从同步开启的时候,slave上会创建2个线程。

I/O线程。该线程连接到master机器,master机器上的binlog dump线程会将binlog的内容发送给该I/O线程。该I/O线程接收到binlog内容后,再将内容写入到本地的relay log。 SQL线程。该线程读取I/O线程写入的relay log。并且根据relay log的内容对slave数据库做相应的操作。

3.4如何在master、slave上查看上述的线程?

使用SHOW PROCESSLIST命令可以查看。

如图,在master机器上查看binlog dump线程。

如图,在slave机器上查看I/O、SQL线程。

4、讲了这么多,一图以蔽之

5、关于实战

关于实战,请参考我的另一篇文章:Mysql主从同步实战

标签: Mysql主从同步的实现原理

本文链接地址:https://www.jiuchutong.com/biancheng/349920.html 转载请保留说明!

上一篇:详解Mysql主从同步配置实战

下一篇:Mac下MySQL初始化密码操作(mysql mac启动)

  • 企业向银行贷款属于融资吗
  • 记账凭证核算形式是会计核算中最基本的核算形式
  • 支付办公楼维修费
  • 文化服务费内容是什么
  • 在建工程明细科目
  • 转账支票需要哪些资料
  • 计提业务招待费和办公费需要附件吗?
  • 如何知道企业交了多少税
  • 文化事业建设费的征收范围
  • 工程项目分包需要缴纳企业所得税吗
  • 活动费的税率
  • 雇佣临时工发生意外能追房东赔偿吗
  • 稿酬所得的个税计算
  • 什么人适用131419手机号码
  • 固定资产折旧金额影响因素
  • 1697510816
  • 公司基本户买理财产品,怎么记账
  • 职工福利费的构成
  • chrom无法访问
  • windows7中
  • redis使用php
  • php常见面试问题
  • 股权和债权转让的关系
  • 吊兰怎么养才能开花
  • 微软的客户主要是什么
  • php rewind
  • thinkphp uuid
  • PHP:imagecolorexactalpha()的用法_GD库图像处理函数
  • 以公允价值计量的金融资产不计提损失准备
  • php静态函数
  • 【Pytorch深度学习实战】(11)变分自动编码器(VAE)
  • uniapp返回上一页不刷新
  • 关于成本核算的论文题目
  • 新制度设置了应缴财政款科目原制度设置了什么科目
  • 施工单位奖金分配方案
  • 公司帐户到银行怎么取钱
  • 增值税为什么不能在税前扣除
  • Vite + Vue2 + Vuetify2 + <script setup> + TypeScript 搭配开发项目
  • 帝国cms怎么调用文章随机段落
  • 转出未交增值税最终怎么转平
  • 小企业会计准则适用于哪些企业
  • 医院怎么开发票?
  • 汇算清缴是什么
  • 专用发票的用途
  • 小规模普票怎么开
  • 开劳务发票需要的资料有哪些?
  • 什么是增值税的销项税额
  • 用材料抵扣货款通知怎样写
  • 财政补助收入怎样申报企业所得税
  • 汽车高速公路收费卡
  • 固定资产抵扣过处置还能简易计税吗
  • 市政配套费交给哪个部门
  • 行政单位固定资产标准
  • 阿里云 mybase
  • 通过分析SQL语句的执行计划优化SQL
  • win8升级win10系统会卡吗
  • macbookzen
  • mac版cad2022使用教程
  • win10 怎么恢复
  • xp电脑状态栏跑到左边了怎么设置回来
  • 千元以内电脑
  • pavprsrv.exe - pavprsrv是什么进程 有什么用
  • w10怎么创建此电脑
  • win8启动后的初始界面
  • cocos creator 发布web
  • android 开发 教程
  • javascript that
  • 批处理实现电脑登陆二次验证
  • unity3ds
  • unity data
  • js class实现原理
  • jquery加载图片
  • android 属性动画改变view大小
  • 美国消费比例
  • 天津怎么网上交电费
  • 怎么代理保险业务
  • 大连地税局发票怎么开
  • 营业账簿中的其他账簿包括
  • 建设工程勘察设计单位可跨部门跨地区承揽勘察设计业务
  • 个人可不可以申请办理租赁性质车辆登记
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设