1.主从复制原理
架构图
(图片摘自linux公社)
线程 | 作用 |
BinLog Dump | 运行在主库,是在从库启动复制时生成的,获取二进制文件 |
I/O | 向主库要数据,写到自身中继日志中(relay log) |
SQL | 将relay log 的变更时间更新到从库 |
流程:
主库将变更时间写到二进制文件bin-log中,从库的I/O线程将二进制文件取到,存入自己的中继日志relay-log中,用SQL线程写入从库,使得主从数据一致。
详细流程如下(本段摘自linux公社): 主库验证从库发起的连接; 主库为从库开启一个线程; 从库将主库日志的偏移位告诉主库; 主库检查该值是否小于当前二进制日志偏移位。 如果小于,则通知从库可以取数据。 从库持续从主库取数据,直至取完,这时,从库线程进入睡眠,主库线程同时进入睡眠。 当主库有更新时,主库线程被激活,并将二进制日志推送给从库,并通知从库线程进入工作状态。 从库SQL线程执行二进制日志,随后进入睡眠状态。
环境验证
MySql:5.6.20
OS: Centos7.2.1511(2台)
- 主库配置
在/etc/my.cnf中[mysqld]字段加入以下代码 server-id=1 log-bin=mysql-bin
2.从库配置
[mysqld] server-id=2 replicate-do-db = dbname(需要备份的库) replicate-ignore-db = mysql
在master端不指定binlog-do-db,在slave端用replication-do-db来确定需要备份的库
replicate-ignore-db为忽略的库
- 登录主库,创建从库所需用户名,并设置仅从库可访问
CREATE USER 'master'@'从库IP' IDENTIFIED BY 'master123'; grant replication slave on *.* to 'master'@'从库IP' identified by 'master123';
- 记录主库file与position
登录主库: show master status;
- 登录从库,设置连接的主库,并启动slave
mysql>stop slave; mysql>change master to master_host='主库IP',master_port=3306,master_user='master',master_password='master123',master_log_file='mysql-bin.000009',master_log_pos=120; mysql>start slave;
- 查看复制状态,登录从库执行看到两个yes即可
mysql>show slave status \G;