mysql主从同步原理及配置

mysql主从同步配置

主从同步原理:

master开启bin-log功能,日志文件用于记录数据库的读写增删,
需要开启3个线程,master IO线程,slave开启 IO线程 SQL线程,
Slave 通过IO线程连接master,并且请求某个bin-log,position之后的内容。
MASTER服务器收到slave IO线程发来的日志请求信息,io线程去将bin-log内容,position返回给slave IO线程。
slave服务器收到bin-log日志内容,将bin-log日志内容写入relay-log中继日志,创建一个master.info的文件,该文件记录了master ip 用户名 密码 master bin-log名称,bin-log position。
slave端开启SQL线程,实时监控relay-log日志内容是否有更新,解析文件中的SQL语句,在slave数据库中去执行。

在这里插入图片描述

master配置my.ini

步骤一:在my.ini配置文件中添加配置

#确定master服务id
server-id=1
#保存二进制文件
log-bin=mysql-bin
#记录master的操作日志
log="D:/mysql/master/master.log"

在这里插入图片描述

步骤二:重启服务,查看效果

修改了配置文件之后需要重启服务,重启之后可以发现在master根目录里面生成了master.log日志文件,并在data文件夹中生成了名称为mysql-bin的二进制文件
在这里插入图片描述
在这里插入图片描述

slave配置my.ini

slave不需要保存二进制文件,修改好了之后重启服务

在这里插入图片描述
注:服务id不冲突重复即可

master授权帐号

GRANT REPLICATION SLAVE ON *.* to '用户名'@'slave的IP' identified by ‘密码’

在这里插入图片描述
授权执行完成之后可以通过show master status查看master状态

在这里插入图片描述

file:二进制文件名 position:定位

slave端执行语句

在这里插入图片描述
步骤一:

change master to
master_host='192.168.77.1',#master IP
master_user='lvtest',#master数据库通过GRANT授权的账号
master_password='admin',#master数据库通过GRANT授权的密码
master_port=3307,#master端口号
master_log_file='mysql-bin.000001', #show master status显示的File名称
master_log_pos=296 #show master status显示的Position的值

步骤二:刷新服务

start slave

步骤三:查看slave状态

show slave status

查询结果中如果Slave_IO_Running、Slave_SQL_Running两个字段都是yes说明成功

Slave_IO_Running:IO读取日志没问题

Slave_SQL_Running:还原sql没问题

注意事项

1.slave从数据库只能读,如果在slave中进行增删改会导致主从同步失效

失效解决方案:

1.执行sql语句stop slave关闭slave。

2.重新执行 slave端执行语句 的步骤,重点是 master_log_pos 设置的值要更新,

所以先去master中通过show master status 语句查询最新的position字段的值进行更新。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值