位置: 编程技术 - 正文

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启动)

  • 当月红冲发票账务怎么处理
  • 消防公司支付劳务费会计处理
  • 员工工资占公司收入比例怎么算
  • 季度申报后还要年度申报吗
  • 咨询服务合同印花税税目
  • 应付工资可以挂账多长时间
  • 免费提供客户试用卷的账务处理?
  • 建帐时库存的原材料如何入帐?
  • 材料短缺赔偿会计分录怎么写?
  • 固定资产处置的账务处理
  • 工会经费 管理费用
  • 分期收款发出商品属于什么科目
  • 固定资产发现入账错误折旧如何处理?
  • 法院扣款图片
  • 金蝶k3外购入库核算没单据
  • mac怎么airdrop给ipad
  • 稽查补交的税款怎么处理
  • 退回多收款项开具发票原发票需要退回吗
  • 支付航天开票技术服务费280
  • 处置控制的子公司有哪些
  • mac怎么共享文件
  • PHP If Else(elsefi) 语句
  • 报关代理费是什么
  • 销售额是否含税?
  • 研发费用支出税前扣除比例
  • vant3.0
  • 稳岗补贴需要缴纳什么税
  • 逾期未收回包装物押金增值税
  • 原材料入库时如何计价
  • 大雾笼罩的早晨
  • django-cors-headers
  • vue中的组件有几类
  • 浦东森林村
  • 多表联动查询
  • sql server2016使用
  • vue权限控制设计
  • php判断时间区间
  • 付临时工工资需要什么材料
  • 为什么没缴税
  • 研发费用大于收入
  • 党费结算标准
  • 风险资本生存概率
  • 当月确认收入可以下月确认成本吗
  • java面试相关
  • 预支报销单
  • 商品入库进项税不抵扣会计分录
  • 年金一定是一年一次吗
  • 支付劳务费后缴多少税
  • 商业承兑汇票怎么做账
  • 出口免费样品怎么做账
  • 建筑业负数发票不填工程名称和地址可以吗
  • 货款折扣的账务处理
  • 收到了对方的作业怎么办
  • 盘盈的固定资产怎么处理
  • 物流公司保险怎么买
  • 股权转让如何支付利润
  • 固定资产如何管理可以做到节能减排
  • 消费税的科目设置在哪里
  • mysql 定点数和浮点数
  • ubuntu gz
  • windows8休眠如何唤醒
  • freebsd中文手册
  • linux里cat命令
  • linux系统bug
  • windows用户如何添加新用户账户信息
  • 安装centos7.7
  • win8的显示设置
  • win8系统怎样
  • win7耳机和外放一起响
  • js下拉加载
  • nodejs内置的包管理器
  • 标题显示不出来
  • js弹出提示窗口
  • javascript怎么弄
  • python多进程共享对象
  • android混淆后怎么破解
  • 山东税务是干什么的
  • 定额发票作废了还能报销吗
  • 个人所得税网上报税流程
  • 增值税申报表如何下载
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设