MySQL在不锁表情况下的主从同步配置

46 篇文章 0 订阅
3 篇文章 0 订阅

一般情况下,我们都是在新安装MySQL的同时配置主从同步,但是也许会遇到在业务跑了一段时间后,需要给数据库配置主从同步的情况。面对这种情况,作为菜鸟的我,会先再主库锁表,导出数据,传送到从库服务器,接着是导入从库,然后在从库change master。这显然很麻烦。不经意间听到大佬说,在不锁表的情况下也可以配置主从同步。

配置流程大致如下:
1、从主库导出已有数据

mysqldump --skip-lock-tables --single-transaction --flush-logs --hex-blob  -uroot -p --master-data=2 -A > master.sql
**参数解析**
--skip-lock-tables 不锁表
--master-data=2 在导出的时候同时生成binlog文件名和位置在导出的文件开头。这个很重要。因此第4步(show master status)也不需要执行了,binlog的文件和位置可以从这里拿到。
--master-data=1 时 不注释change语句
--single-transaction 通过将导出操作封装在一个事务内来使得导出的数据是一个一致性快照

此外,我们不必在master上执行“show master status;”去找主库的pos和logfile了,这两个参数会在导出的sql文件(master.sql)里,大概在前100行。

2、将备份的数据拷贝到从库服务器

3、将数据导入从库

4、从库连接master

#查看从主库拷贝过来的SQL文件(master.sql),会在前100行看到这样一行“CHANGE MASTER TO MASTER_LOG_FILE='mysql-bin.000003', MASTER_LOG_POS=154;”,
#这就是master的pos和logfile,也即是下面需要CHANGE MASTER语句中用到的‘MASTER_LOG_FILE’和‘MASTER_LOG_POS’
CHANGE MASTER TO MASTER_HOST='192.168.1.222', \
MASTER_PORT=3306, \
MASTER_USER='repl', \
MASTER_PASSWORD='your_password', \
MASTER_LOG_FILE='mysql-bin.000003', \
MASTER_LOG_POS=154;

5、从库启动复制

start slave;

6、查看主从同步状态

show slave status\G
  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值