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

一般情况下,我们都是在新安装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

你可能感兴趣的:(运维,CentOS,Mysql)