MySQL备份工具XtraBackup的使用
MySQL备份工具XtraBackup的使用xtrabackup简介
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具。特点:
(1)备份过程快速、可靠;
(2)备份过程不会打断正在执行的事务;
(3)能够基于压缩等功能节约磁盘空间和流量;
(4)自动实现备份检验;
(5)还原速度快;
官方下载地址:地址,你可以通过此链接下载最新版。
#wget https://www.percona.com/downloads/XtraBackup/Percona-XtraBackup-2.4.8/binary/redhat/7/x86_64/percona-xtrabackup-24-2.4.8-1.el7.x86_64.rpm
# yum install ./percona-xtrabackup-24-2.4.8-1.el7.x86_64.rpm 使用yum的本地安装方式解决其依赖关系
xtrabackup包含两个主要的工具,即xtrabackup和innobackupex,二者区别如下:
(1)xtrabackup只能备份innodb和xtradb两种引擎的表,而不能备份myisam引擎的表;
(2)innobackupex是一个封装了xtrabackup的Perl脚本,支持同时备份innodb和myisam,但在对myisam备份时需要加一个全局的读锁。还有就是myisam不支持增量备份。
权衡两者区别,建议使用innobackupex工具进行备份。
备份恢复过程
全量备份
其备份过程如下图所示(该图来源于网络):
备份开始时首先会开启一个后台检测进程,实时检测mysql redo的变化,一旦发现redo中有新的日志写入,立刻将日志记入后台日志文件xtrabackup_log中。之后复制innodb的数据文件和系统表空间文件ibdata1,待复制结束后,执行flush tables with read lock操作,复制.frm,MYI,MYD,等文件(执行flush tableswith read lock的目的是为了防止数据表发生DDL操作,并且在这一时刻获得binlog的位置)最后会发出unlock tables,把表设置为可读可写状态,最终停止xtrabackup_log。
全备恢复
这一阶段会启动xtrabackup内嵌的innodb实例,回放xtrabackup日志xtrabackup_log,将提交的事务信息变更应用到innodb数据/表空间,同时回滚未提交的事务(这一过程类似innodb的实例恢复)。恢复过程如下图:
增量备份
innobackupex增量备份过程中的"增量"处理,其实主要是相对innodb而言,对myisam和其他存储引擎而言,它仍然是全拷贝(全备份)。
"增量"备份的过程主要是通过拷贝innodb中有变更的"页"(这些变更的数据页指的是"页"的LSN大于xtrabackup_checkpoints中给定的LSN)。增量备份是基于全备的,第一次增备的数据必须要基于上一次的全备,之后的每次增备都是基于上一次的增备,最终达到一致性的增备。增量备份的过程如下,和全备的过程很类似,区别仅在第2步。
增备恢复
和全备恢复类似,也需要两步,一是数据文件的恢复,如下第一幅图,这里的数据来源由3部分组成:全备份,增量备份和xtrabackup log。二是对未提交事务的回滚,如下第二幅图所示:
XtraBackup使用示例
创建备份用户
如果要使用一个最小权限的用户进行备份,则可基于如下命令创建此类用户:
MariaDB [(none)]> CREATE USER 'bkpuser'@'localhost'>
MariaDB [(none)]> GRANT> MariaDB [(none)]> FLUSH PRIVILEGES;
#创建一个测试数据库并添加内容
# mysql -pshow databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| performance_schema |
| zachary |
+--------------------+
4 rows in set (0.02 sec)
MariaDB [(none)]> select * from zachary.test;
+----+-------------+
|> +----+-------------+
|1 | yangzhiheng |
+----+-------------+
1 row in set (0.01 sec)
数据已恢复
使用XtraBackup进行增量备份
每个InnoDB的页面都会包含一个LSN信息,每当相关的数据发生改变,相关的页面的LSN就会自动增长。这正是InnoDB表可以进行增量备份的基础,即innobackupex通过备份上次完全备份之后发生改变的页面来实现。
准备一个数据变化
# mysql -p < test2.sql
# cat test2.sql
insert into zachary.test(id,name) values(2,'zachary');
insert into zachary.test(id,name) values(3,'tom');
insert into zachary.test(id,name) values(4,'jarry');
备份:
# innobackupex --user=bkpuser --password=bkppass --incremental /backup --incremental-basedir=/backup/2017-11-27_04-40-55/
其中,--incremental-basedir参数指的是完全备份所在的目录,此命令执行结束后,innobackupex命令会在/backup目录中创建一个新的以时间命名的目录以存放所有的增量备份数据。另外,在执行过增量备份之后再一次进行增量备份时,其--incremental-basedir应该指向上一次的增量备份所在的目录。
需要注意的是,前文已讲述过,增量备份仅能应用于InnoDB或XtraDB表,对于MyISAM表而言,执行增量备份时其实进行的是完全备份。
Prepare一个增量备份
“准备”(prepare)增量备份与整理完全备份有着一些不同,尤其要注意的是:
(1)需要在每个备份(包括完全和各个增量备份)上,将已经提交的事务进行“重放”。“重放”之后,所有的备份数据将合并到完全备份上。
(2)基于所有的备份将未提交的事务进行“回滚”。
于是,操作就变成了:
# innobackupex --apply-log --redo-only /backup/2017-11-27_04-40-55/
接着执行:
# innobackupex --apply-log --redo-only /backup/2017-11-27_04-40-55/ --incremental-dir=/backup/2017-11-27_05-23-52
如果后面有其他增量的话,可以按时间顺序执行其他增量操作
# innobackupex --apply-log --redo-only BASE-DIR --incremental-dir=INCREMENTAL-DIR-2
其中BASE-DIR指的是完全备份所在的目录,而INCREMENTAL-DIR-1指的是第一次增量备份的目录,INCREMENTAL-DIR-2指的是第二次增量备份的目录,其它依次类推,即如果有多次增量备份,每一次都要执行如上操作
Prepare之后按照之前全量备份恢复所使用的操作来进行恢复,这里不再详述。
本篇文章还未写完,后期会补上。
页:
[1]