设为首页 加入收藏

TOP

利用XtraBackupp实现不停master服务做主从同步
2015-08-31 19:59:31 来源: 作者: 【 】 浏览:29
Tags:利用 XtraBackupp 实现 不停 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),以达到数据的一致性。


备份分为两个过程:


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


利用XtraBackupp实现不停master服务做主从同步


三.在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状态:


利用XtraBackupp实现不停master服务做主从同步


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Zabbix 的 MySQL 监控客户端配置 下一篇通过 XtraBackup 实现不停机不锁..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: