MySql主从复制原理及其搭建

1.主从复制原理

架构图图片摘自linux公社
(图片摘自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台)

  1. 主库配置
在/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为忽略的库

  1. 登录主库,创建从库所需用户名,并设置仅从库可访问
CREATE USER 'master'@'从库IP' IDENTIFIED BY 'master123';
grant replication slave on *.* to 'master'@'从库IP' identified by 'master123';
  1. 记录主库file与position
登录主库:
show master status;
  1. 登录从库,设置连接的主库,并启动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;
  1. 查看复制状态,登录从库执行看到两个yes即可
mysql>show slave status \G;
  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

早九晚十二

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

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

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

打赏作者

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

抵扣说明:

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

余额充值