XtraBackup增量备份和恢复

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

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

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

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

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

由上图可以看出往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_checkpoints文件。

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

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

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

可以看到第二次增量备份的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

停止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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

#慧#

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值