17.2.1 Replication Implementation Details 复制实施细节

MySQL复制功能通过3个线程实现:主服务器的Binlog Dump线程和从服务器的 Slave I/O、SQL线程。Binlog Dump线程负责将主服务器的二进制日志发送给从服务器,Slave I/O线程接收并写入中继日志,而SQL线程读取并执行中继日志中的更新。这种设计使得即使SQL执行慢也不会影响从服务器的读取速度,确保了数据的安全性和连续性。
摘要由CSDN通过智能技术生成

17.2.1 Replication Implementation Details 复制实施细节

MySQL 复制能力实现使用3个threads,一个在master上,另外2个在slave上:

Binlog dump thread, master创建一个thread 来发送binary log 内容到一个slave,当slave连接的时候。

这个线程可以在SHOW PROCESSLIST 数据中看到:

binary log dump thread 需要一个lock 在master 的binary log 用于读取要发送给slave的evnet.

当event被读取后,lock 释放, 甚至在event被发送给slave前。

Slave I/O thread, 当START SLAVE 语句在slave server上被执行,slave创建一个I/O thread,

slave连接到master,告诉master 发送它的binary log里的更新的内容

slave I/O 线程 读取 master的binlog dump thread 发送和复制它们到本地的文件,组成slave的relay log.

Slave SQL thread,slave 创建一个SQL thread 读取relay log ,是由slave I/O thread 写入。

在前面的描述中, 有三个线程 每个master/slave 连接。

一个master 有多个slave 创建一个binary log dump thread 为每个连接的slave,

每个slave 有它自己的I/O 和SQL threads.

一个slave 使用2个thread 来分别的从master 读取更新和,并执行它们成为单独的任务。

因此,如果读取语句的任务不会慢下来 如果执行语句是慢的。

例如, 如果slave server 有一段时间没有运行,它的I/O thread 可以很快的获取所有的bina

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

scan724

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值