一、XtraBackup简介与安装

  XtraBackup是一款免费的在线开源数据库备份解决方案,适用于所有版本的MySQL和MariaDB。XtraBackup支持对InnoDB热备,是一款物理备份工具。可对数据库做完全备份、部分备份、增量备份、差异备份。

1.备份的实现原理

  InnoDB存储引擎是基于表空间(table space)进行存储的,表空间中被分成多个块(盘区),将数据分散存储至这些盘区中,每个盘区都有自己的编号,每当数据修改一次,日志序列号就增加1。在完全备份时,是将所有的盘区进行一次物理备份,而增量备份则是根据被修改的盘区号所导致的epoch变化选择性备份相对完全备份所被修改的盘区。例如下图中为某个数据库InnoDB引擎的盘区,完全备份是将1-5盘区全部备份,后来数据库被修改了,修改的数据是盘区1和3的数据,做增量备份时会将1和3号盘区进行备份。在做还原时会先还原完全备份中的1-5,再还原增量中的1和3。

  需要注意的是,在XtraBackup中,是将完全备份和所有的增量合并之后才进行对数据库还原操作的,不是在还原时合并的,是在还原之前就将所有数据合并好。

2.XtraBackup的安装

  Percona官方站点安装:https://www.percona.com/downloads/XtraBackup/LATEST/

  下载完成后安装,用yum安装会自动安装依赖包:

~]# yum install percona-xtrabackup--2.4.-.el7.x86_64.rpm percona-xtrabackup-test--2.4.-.el7.x86_64.rpm
 ~]# rpm -ql percona-xtrabackup-
/usr/bin/innobackupex #主程序,核心组件,一般都是用这一工具进行备份
/usr/bin/xbcloud
/usr/bin/xbcloud_osenv
/usr/bin/xbcrypt
/usr/bin/xbstream #流式化工具,将数据流式化处理,便于传输保存
/usr/bin/xtrabackup
/usr/share/doc/percona-xtrabackup--2.4.
/usr/share/doc/percona-xtrabackup--2.4./COPYING
/usr/share/man/man1/innobackupex..gz
/usr/share/man/man1/xbcrypt..gz
/usr/share/man/man1/xbstream..gz
/usr/share/man/man1/xtrabackup..gz

二、XtraBackup功能演示

  上面已经介绍了XtraBackup支持增量备份的核心组件是LSN(日志序列号)。在恢复前需要先进行合并操作。

1.全量的备份

  全量备份格式:

innobackupex --user=DBUSER --password=DBUSERPASS /path/to/BACKUP-DIR/

  选项:

--no-timestamp :保存的备份目录不加时间戳

--defaults-file=/tmp/other-my.cnf :配置文件路径

/path/to/BACKUP-DIR/ :指明将备份存储在哪个目录

2.全量的恢复

  全量恢复前需要先做Preparing,将备份本身的事务按实际情况做回滚或提交:

innobackupex --apply-log /path/to/BACKUP-DIR

--apply-log :根据事务日志判断哪些该提交哪些该回滚

  然后执行:

innobackupex --copy-back BASE-DIR #BASE-DIR为备份的路径

3.增量的备份

  增量备份需要基于全量备份来实现,在第一次做增量备份时指令中需要制定基于哪一个全量备份来做增量备份,之后的增量备份则都要基于上一次的增量备份来做,而差异备份则每一次都是基于全量备份,如图:

innobackupex --incremental /data/backups --incremental-basedir=BASEDIR

--incremental /data/backups :指明增量备份保存的路径

--incremental-basedir=BASEDIR :指明增量备份基于哪一个全量备份

  每一次备份后XtraBackup会保存一个文件,在这个文件中记录了,备份的类型、LSN的起始点和结束点。例:

 backup_type = full-backuped
from_lsn =
to_lsn =

4.增量的恢复

  在还原全量+增量时,全量有事务日志被备份,增量也有事务日志被备份,这时需要将全量中的已提交(COMMITED)的事务做还原,而未提交的部分不用做处理,待与增量中的事务合并后在进行回滚,因为全量中的事务可能在增量中有变化。

  先对全量操作,:

innobackupex --apply-log --redo-only BASE-DIR

--redo-only :只恢复事务中已提交的

  再对增量操作,将全量与增量合并:

innobackupex --apply-log BASE-DIR --incremental-dir=INCREMENTAL-DIR2

  最后进行一次回滚:

innobackupex --apply-log BASE-DIR

  还原:

innobackupex --copy-back BASE-DIR

  查看innobackupex指令帮助:

innobackupex --help

XtraBackup的备份原理与应用示例的更多相关文章

  1. 从源码分析 XtraBackup 的备份原理

    MySQL物理备份工具,常用的有两个:MySQL Enterprise Backup 和 XtraBackup. 前者常用于MySQL企业版,后者常用于MySQL社区版.Percona Server ...

  2. mysqldump和xtrabackup备份原理实现说明

    背景: MySQL数据库备份分为逻辑备份和物理备份两大类,犹豫到底用那种备份方式的时候先了解下它们的差异: 逻辑备份的特点是:直接生成SQL语句,在恢复的时候执行备份的SQL语句实现数据库数据的重现. ...

  3. MariaDB/MySQL备份和恢复(三):xtrabackup用法和原理详述

    本文目录: 1.安装xtrabackup 2.备份锁 3.xtrabackup备份原理说明 3.1 备份过程(backup阶段) 3.2 准备过程(preparing阶段) 3.3 恢复过程(copy ...

  4. Percona XtraBackup 备份原理说明【转】

    本文来自:http://mysql.taobao.org/monthly/2016/03/07/ 前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MyS ...

  5. MySQL · 物理备份 · Percona XtraBackup 备份原理

    http://mysql.taobao.org/monthly/2016/03/07/ 前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据 ...

  6. Percona XtraBackup 备份原理

    前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server 和 ...

  7. XtraBackup完整备份与增量备份的原理

    MySQL数据库实现备份的操作包括完整备份和增量备份等,本文我们主要介绍一下增量备份和完整备份的原理,接下来我们就一起来了解一下这部分内容. 完整备份的原理: 对于InnoDB,XtraBackup基 ...

  8. XtraBackup 备份原理

    来着淘宝技术: http://mysql.taobao.org/monthly/2016/03/07/ https://github.com/alibaba/AliSQL 前言 Percona Xtr ...

  9. mysqldump+mydumper+xtrabackup备份原理流程

    mysqldump备份原理 备份的基本流程如下: 1.调用FTWRL(flush tables with read lock),全局禁止读写 2.开启快照读,获取此时的快照(仅对innodb表起作用) ...

随机推荐

  1. spring jdbc 记录

    @Repository("com.example.demo.dao.impl.SmpUserDaoImpl") public class SmpUserDaoImpl implem ...

  2. SpringBoot集成redis,使用@Cachexxxx

    一.引入相关依赖: <dependency> <groupId>org.springframework.boot</groupId> <artifactId& ...

  3. 学习Acegi应用到实际项目中(4)

    此节介绍:ConcurrentSessionFilter. 在Acegi 1.x版本中,控制并发HttpSession和Remember-Me认证服务不能够同时启用,它们之间存在冲突问题. 在一些应用 ...

  4. oracle表空间扩容方法

    1.使用navicat连接要扩容的数据库,进入其他-表空间 2.添加数据文件和设置配置项即可

  5. 我的第一个python爬虫

    我的第一个爬虫,哈哈,纯面向过程 实现目标: 1.抓取本地conf文件,其中的URL地址,然后抓取视频名称以及对应的下载URL 2.抓取URL会单独写在本地路径下,以便复制粘贴下载 废话补多少,代码实 ...

  6. 20155326刘美岑 Exp6 信息收集与漏洞扫描

    20155326刘美岑 Exp6 信息收集与漏洞扫描 实验后回答的问题 (1)哪些组织负责DNS,IP的管理. 全球根服务器均由美国政府授权的ICANN统一管理,负责全球的域名根服务器.DNS和IP地 ...

  7. PHP字符串函数之 strcmp strncmp strcasecmp strncasecmp strnatcmp strnatcasecmp

    strcmp – 二进制安全字符串比较 strncmp – 二进制安全比较字符串开头的若干个字符 strcasecmp – 二进制安全比较字符串(不区分大小写) strncasecmp – 二进制安全 ...

  8. Python自动化开发 - 堡垒机实例

    本节内容 一.堡垒机介绍 1. SSHClient 2. SFTPClient 3. Transport 二.堡垒机实现 一.堡垒机介绍 1. SSHClient 用户连接远程服务器并执行基本命令 1 ...

  9. .NET Core微服务之路:让我们对上一个Demo通讯进行修改,完成RPC通讯

    最近一段时间有些事情耽搁了更新,抱歉各位了. 上一篇我们简单的介绍了DotNetty通信框架,并简单的介绍了基于DotNetty实现了回路(Echo)通信过程. 我们来回忆一下上一个项目的整个流程: ...

  10. AndroidStudio制作个人资料界面模块以及SQLite数据库的使用

    前言 大家好,给大家带来AndroidStudio制作个人资料界面模块以及SQLite数据库的使用的概述,希望你们喜欢 学习目标 掌握SQLite数据库的使用,能够实现用数据库来保存用户的信息: 学会 ...