利用xtraBackup实现不停master服务做主从同步
MySQL主从同步原理:
MySQL主从同步是在MySQL主从复制(Master-Slave Replication)基础上实现的,通过设置在Master MySQL上的binlog(使其处于打开状态),Slave MySQL上通过一个I/O线程从Master MySQL上读取binlog,然后传输到Slave MySQL的中继日志中,然后Slave MySQL的SQL线程从中继日志中读取中继日志,然后应用到Slave MySQL的数据库中。这样实现了主从数据同步功能。
XtraBackup备份原理:
innobackupex在后台线程不断追踪InnoDB的日志文件,然后复制InnoDB的数据文件。数据文件复制完成之后,日志的复制线程也会结束。这样就得到了不在同一时间点的数据副本和开始备份以后的事务日志。完成上面的步骤之后,就可以使用InnoDB崩溃恢复代码执行事务日志(redo log),以达到数据的一致性。
备份分为两个过程:
backup,备份阶段,追踪事务日志和复制数据文件(物理备份)。
preparing,重放事务日志,使所有的数据处于同一个时间点,达到一致性状态。
XtraBackup的优点:
可以快速可靠的完成数据备份(复制数据文件和追踪事务日志)
数据备份过程中不会中断事务的处理(热备份)
节约磁盘空间和网络带宽
自动完成备份鉴定
因更快的恢复时间而提高在线时间
一 xtrabackup安装:
yum -y install perl perl-devel libaio libaio-devel perl-Time-HiRes perl-DBD-MySQL
rpm -ivh percona-xtrabackup-2.2.12-1.el6.x86_64.rpm
软件下载地址:https://www.percona.com/software/mysql-database/percona-xtrabackup
二 核对mysql的版本:
利用xtrabackup做全备和恢复的,Mysql的版本最好一致!
检查mysql版本:
/webser/mysql55/bin/mysql -V
/webser/mysql55/bin/mysql Ver 14.14 Distrib 5.5.21, for Linux (x86_64) using readline 5.1
三.在master服务器上在线备份数据库:
innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx /tmp/backup/
PS:/tmp/backup/ 为备份目录;
然后通过scp方式把master上
四.slave机器上操作;
1)关闭mysql服务;
然后清空mysql数据目录下文件,例如本机mysql的数据目录是:/webser/mysql55/var/
2)开始恢复数据
假设备份文件的路径在:/webser/2015-08-12_13-54-56
恢复日志文件:
innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --apply-log /tmp/backup/2015-08-12_13-49-32/
恢复数据文件:
innobackupex --defaults-file=/webser/mysql55/etc/my.cnf --user=root --password=xxxx --copy-back /tmp/backup/2015-08-12_13-49-32/
以上操作,请务必按照顺序执行,操作顺序颠倒,会引起mysql服务器启动不了!
3)修改数据目录权限:
chown -R mysql:mysql /webser/mysql55/var
4)安全方式启动mysql,查看是否有异常;
/webser/mysql55/bin/mysqld_safe --defaults-file=/webser/mysql55/etc/my.cnf &
如果没有异常报错,就关闭mysql
/webser/mysql55/bin/mysqladmin -uroot -p shutdown
5)查看binlog日志文件的位置值,做主从同步:
cat /tmp/backup/2015-08-12_13-49-32/xtrabackup_binlog_info
wwwmaster.000458 1022022953
6)在slave机器上做主从相关操作:
CHANGE MASTER TO
MASTER_HOST='192.168.1.xxx',
MASTER_USER='rep',
MASTER_PASSWORD='xxxxxx',
MASTER_PORT=3306,
MASTER_LOG_FILE='wwwmaster.000458',
MASTER_LOG_POS=1022022953;
启动主从同步:
start slave;
查看slave状态: