首先,先进行全备,全备的命令如下所示:
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