mysql主从同步

由于最近一直忙于工作,难有 有时间更新技术文章,一直一来想写几篇关于mysql主从同步的文章,今天难得有时间,现将拙见发表于此:mysql 主从同步分为 原理篇 和实战篇:

1、 什么是主从同步?

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

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

水平扩展数据库的负载能力。

容错,高可用。Failover(失败切换)/High Availability

数据备份

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

3.1 先来了解下主从的架构 Master-slave

我们平常所接触到的高并发或者大流量的网站和移动应用,select查询 最多,正因为如此我们可以通过主从分离来实现数据库的减压负载,在mysql master 机上实现delete update insert ,而从库slave 上进行大量的select :这时就需要不管是delete、update、insert,还是创建函数、存储过程,所有的操作都在master上。当master有操作的时候,slave会快速的接收到这些操作,从而做同步。

3.2 主从同步又是如何实现的呢?

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

3.3主从实现的过程

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

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

statement:会将对数据库操作的sql语句写入到binlog中。

row:会将每一条数据的变化写入到binlog中。

mixed:statement与row的混合。Mysql决定什么时候写statement格式的,什么时候写row格式的binlog

3.4 在master机器上的操作

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

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

3.5 在slave机器上的操作

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

1. I/O线程。该线程连接到master机器,master机器上的binlog dump线程会将binlog的内容发送给该I/O线程。该I/O线程接收到binlog内容后,再将内容写入到本地的relay log。

2. SQL线程。该线程读取I/O线程写入的relay log。并且根据relay log的内容对slave数据库做相应的操作。

3.6 如何查看 master slave线程

使用SHOW PROCESSLIST命令可以查看。

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

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

4、讲了这么多,一图解之

5实战后续。。。。。

  • 发表于:
  • 原文链接https://kuaibao.qq.com/s/20180608G21YCU00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券