通过innobackupex实现对MySQL的增量备份与还原
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了通过innobackupex实现对MySQL的增量备份与还原相关的知识,希望对你有一定的参考价值。
备份
增量备份是基于完整备份的,所以我们需要先做一次完整备份:
innobackupex --password=test /backup/
备注:test是我的mysql服务的root用户的密码,/backup/是我用于存放备份文件的目录。
执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-45-26/。
第一次增量备份:
innobackupex --password=test --incremental /backup/ --incremental-basedir=/backup/2016-09-20_14-45-26/
注意:第一次备份的--incremental-basedir参数应指向完整备份的时间戳目录。
执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-58-01/。
第二次增量备份:
innobackupex --password=test --incremental /backup/ --incremental-basedir=/backup/2016-09-20_14-58-01/
注意:第二次备份的--incremental-basedir参数应指向第一次增量备份的时间戳目录。
执行完命令后,/backup/目录下会生成一个时间戳目录,在我这个例子中是/backup/2016-09-20_14-58-30/。
为了达到实验效果,建议读者在每次增量备份前对数据库进行增删改,以便观察还原效果。
还原
停止MySQL服务并清空数据目录:
service mysqld stop
rm -rf /mysql/*
整合完整备份和增量备份:
innobackupex --apply-log --redo-only /backup/2016-09-20_14-45-26/
innobackupex --apply-log --redo-only /backup/2016-09-20_14-45-26/ --incremental-dir=/backup/2016-09-20_14-58-01/
innobackupex --apply-log /backup/2016-09-20_14-45-26/ --incremental-dir=/backup/2016-09-20_14-58-30/
innobackupex --apply-log /backup/2016-09-20_14-45-26/
注意:一定要按照完整备份、第一次增量备份、第二次增量备份的顺序进行整合,在整合最后一次增量备份时不要使用--redo-only参数。
开始还原:
innobackupex --copy-back /backup/2016-09-20_14-45-26/
还原成功后你会看到“completed OK!”的字样。
修改数据目录的属主和属组并启动MySQL服务:
chown -R mysql.mysql /mysql/
service mysqld start
通过以上步骤就完成了增量备份的还原。
温馨提示
在还原时,如果有足够的空间,建议对数据目录和备份目录进行拷贝备份。
以上是关于通过innobackupex实现对MySQL的增量备份与还原的主要内容,如果未能解决你的问题,请参考以下文章
Mysql使用innobackupex在线备份方案(全量+增量)操作记录
MySQL5.7.18 备份Mysqldump,mysqlpump,xtrabackup,innobackupex 全量,增量备份,数据导入导出
通过innobackupex实现对MySQL的完整备份与还原