基于xtrabackup GDIT方式不锁库作主从同步(主主同步同理,反向及可)
1.安装数据同步工具
注:xtrabackup 在数据恢复的时候比mysqldump要快很多,特别是大数据库的时候,但网络传输的内容要多,压缩需要占用时间。
yum install https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.12/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.12-1.el7.x86_64.rpm -y
2.Master上备份数据库并传输
mkdir -p /backup/liubak
cd /backup/liubak
innobackupex --defaults-file=/etc/my.cnf--user=root --password=mysql --port=3306 --slave-info --safe-slave-backup--socket=/tmp/mysql.sock --no-timestamp /backup/liubak
查看xtrabackup_binlog_info信息:
[root@liu01 liubak]# more xtrabackup_binlog_info
bin.000003 1203
[root@liu01 liubak]# scp -r * liu02:/backup/liubak/
3.将备份恢复到slave
复制主/etc/my.cnf文件至从库上面,注意:server-id不能重复。数据库在启用my.cnf后可以正常登录操作。
删除从库data目录下面文件。
innobackupex --apply-log/backup/liubak/
#--apply-log 应用日志
innobackupex --copy-back /backup/liubak/
#--copy-back 把文件按照/etc/my.cnfcopy到数据目录
6.启动数据库
/etc/init.d/mysqld start
7.配置slave replication
CHANGE MASTER TO
MASTER_HOST='192.168.106.4',
MASTER_USER='repl',
MASTER_PASSWORD='repl',
MASTER_LOG_FILE=' bin.000003',
MASTER_LOG_POS=1203;
start slave;
show slave status\G
配置完成。