MySQL 主从复制原理

什么是mysql的主从复制?

MySQL 主从复制指的是数据可以从一个MySQL数据库服务器主节点复制到一个或多个从节点。这里所说的数据可以是主数据库中的所有数据库或者特定的数据库,或者特定的表。

MySQL 主从复制原理

  1. 主库将数据变更写入二进制 binlog 日志。
  2. 从库连接到主库之后,从库有一个 IO 线程,将主库的二进制 binlog 日志拷贝到自己本地,写入 relay 中继日志中。
  3. 接着从库中有一个 SQL 线程会从 relay 中继日志读取 binlog,然后执行 binlog 日志中的内容,也就是在自己本地再次执行一遍 SQL,这样就可以保证自己跟主库的数据是一样的。

大致过程如下:

在这里插入图片描述

其实实际上从库的IO线程不是直接读主库的binlog日志,而是主库有一个IO线程将binlog日志的内容发送到从库的IO线程。如下:
在这里插入图片描述

这里有一个非常重要的点,就是从库同步主库数据的过程是串行化的,也就是说主库上并行的操作,在从库上会串行执行。
由于这个特点,在高并发场景下,从库的数据一定会比主库慢一些,是有延时的。所以刚写入主库的数据可能立马是读不到的,要过几十毫秒,甚至几百毫秒才能读取到。

那么由此衍生出一个问题。

主库宕机,数据会丢失吗?

如果主库突然宕机,然后恰好数据还没同步到从库,那么有些数据可能在从库上是没有的,有些数据可能就丢失了。

MySQL 实际上在这一块有两个机制,一个是半同步复制,用来解决主库数据丢失问题;一个是并行复制,用来解决主从同步延时问题。

半同步复制,也叫 semi-sync 复制,指的就是主库写入 binlog 日志之后,就会将强制此时立即将数据同步到从库,从库将日志写入自己本地的 relay log 之后,接着会返回一个 ack 给主库,主库接收到至少一个从库的 ack 之后才会认为写操作完成了。

所谓并行复制,指的是从库开启多个线程,并行读取 relay log 中不同库的日志,然后并行重放不同库的日志,这是库级别的并行。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值