xinxuaw231 发表于 2018-9-29 07:01:07

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]
查看完整版本: MySQL备份工具XtraBackup的使用