XtraBackup增量备份和恢复

首先,先进行全备,全备的命令如下所示:

innobackupex --defaults-file=/etc/my.cnf --no-timestamp --user root --password 123456 /usr/local/data/backup/all-20181205bak

查看备份目录下的xtrabackup_checkpoints文件,该文件里记录了开始结束的lsn号。

XtraBackup增量备份和恢复_第1张图片

可以看到全备开始的lsn号为0,结束时的lsn号为103210264。

其次在数据库里创建测试数据库test,在test里面建立测试表test.并插入数据如下所示:

XtraBackup增量备份和恢复_第2张图片

由上图可以看出往test表里新增了一行数据,(28,'jack4'),开始第一次增量备份,增量备份的命令如下所示:

innobackupex --defaults-file=/etc/my.cnf  --no-timestamp --user root --password 123456 --incremental /usr/local/data/backup/all-20181206incr  --incremental-basedir=/usr/local/data/backup/all-20181205bak

#其中--incremental 后面的内容是增量备份文件所在路径

#--incremental-basedir  后面接的是指增量备份是基于全备开始的。

#如果实施第二次增备,后面接第一次增量备份的文件,意思是第二次增量备份基于第一次增量备份开始

XtraBackup增量备份和恢复_第3张图片

可以看到增量备份文件已经生成,进入增量备份目录,查看xtrabackup_checkpoints文件。

XtraBackup增量备份和恢复_第4张图片

可以看到备份文件类型是incremental。备份开始的lsn号是全备备份的结束的lsn号。

接着往test表里面再次插入一条数据,(29,'jack5'),再次进行第二次增量备份。

XtraBackup增量备份和恢复_第5张图片

innobackupex --defaults-file=/etc/my.cnf  --no-timestamp --user root --password 123456 --incremental /usr/local/data/backup/all-20181207incr  --incremental-basedir=/usr/local/data/backup/all-20181206incr

XtraBackup增量备份和恢复_第6张图片

可以看到第二次增量备份的lsn号是第一次增量备份的结束lsn号。

增量备份的恢复过程:首先需要进行一次全备恢复,然后再依次进行把增备文件恢复到全备文件中,在这个过程中需要添加--redo-only参数,这就意味着只前滚已经提交的事务,并不回滚那些未提交的事务。最后对整体的全备进行恢复,这时候可以不使用--redo-only参数了。也就是意味着需要回滚那些未提交的事务。

首先,恢复全备的命令如下:

innobackupex --defaults--file=/etc/my.cnf --user root --password 123456 --apply-log --redo-only /usr/local/data/backup/all-20181205bak

接下来进行增量备份的恢复,恢复第一个增备文件至全备文件中,命令如下:

innobackupex --defaults--file=/etc/my.cnf --user root --password 123456 --apply-log --redo-only /usr/local/data/backup/all-20181205bak  --incremental-dir=/usr/local/data/backup/all-20181206.incr

 接下来进行增量备份的恢复,恢复第二个增备文件至全备文件中,命令如下:

innobackupex --defaults--file=/etc/my.cnf --user root --password 123456 --apply-log --redo-only /usr/local/data/backup/all-20181205bak  --incremental-dir=/usr/local/data/backup/all-20181207.incr

 最后在进行一次全备的恢复即可,命令如下,此时不再需要--redo-log参数了。

innobackupex --defaults--file=/etc/my.cnf --user root --password 123456 --apply-log  /usr/local/data/backup/all-20181205bak  

  

模拟表test丢失的情况,删除表test

XtraBackup增量备份和恢复_第7张图片

停止mysql服务

systemctl stop mysqld

#将原来的数据目录重命名为mysql_bak
mv mysql mysql_bak

#重新建立一个文件夹mysql
mkdir mysql

使用下面的命令重新生成新的数据文件:

innobackupex --defaults-file=/etc/my.cnf --copy-back /usr/local/data/backup/all-20181205bak

现在重新启动mysql服务,登录查看test库下的test数据表,可知恢复成功。

systemctl start mysqld

mysql -uroot -p123456

XtraBackup增量备份和恢复_第8张图片

你可能感兴趣的:(mysql,innobackupex,mysql)