xtrabackup备份原理及流式备份应用
xtrabackup备份原理及流式备份应用
0. 参考文献
xtrabackup 是一款开源的MySQL备份解决工具,由percona公司开发完成。相比于MySQL企业版的mysqlbackup 和ibbackup功能强大许多。尤其提供了当前部门需求的流式备份功能,因此在目前看来xtrabackup是一款非常合适的MySQL备份工具。本文将从xtrabackup备份的应用与原理角度介绍xtrabackup。
1. xtrabackup 安装
xtrabackup可以通过多种方式安装。本文在这里选择从https://www.percona.com/downloads/ 下载二进制包的方式安装。在网页中可以看到xtrabackup有4个版本可以选择。这4个版本分别支持MySQL不同的版本:
- 8.0 : MySQL 8.0 以上版本
- 2.4 : MySQL 5.7 版本
- 2.2 和 2.3 : MySQL 5.1, 5.5 和 5.6
当前线上使用的MySQL版本是5.7版本,因此本文所有的内容都是基于2.4版本生成的。如果读者对于8.0 有兴趣,可以阅读其文档:Percona XtraBackup - Documentation
下载下来的文件中,bin目录下会有如下的几个文件:
~/percona-xtrabackup-2.4.15-Linux-x86_64/bin$ ls -la
total 211188
drwxr-xr-x 2 mysql mysql 4096 Oct 12 13:20 .
drwxr-xr-x 6 mysql mysql 4096 Jul 5 16:00 ..
lrwxrwxrwx 1 mysql mysql 10 Jul 5 16:00 innobackupex -> xtrabackup
-rwxr-xr-x 1 mysql mysql 9811072 Jul 5 15:53 xbcloud
-rwxr-xr-x 1 mysql mysql 3020 Jul 5 15:52 xbcloud_osenv
-rwxr-xr-x 1 mysql mysql 5854168 Jul 5 15:53 xbcrypt
-rwxr-xr-x 1 mysql mysql 5942024 Jul 5 15:53 xbstream
-rwxr-xr-x 1 mysql mysql 194628336 Jul 5 15:59 xtrabackup
- xbcloud, xbcloud_osenv : 是xtrabackup新的高级特性云备份
- xbcrypt : 支持加密备份
- xbstream : 支持流式备份功能。可以将备份的内容打包并通过管道传递
- xtrabackup : 是备份功能的主程序
- innobackupex : 这个工具在之前的版本中是一个perl脚本,会调用xtrabackup这个二进制工具。从xtrabackup 2.3开始,该工具使用C语言进行了重写,当前它是xtabackup二进制工具的一个软连接,但是实际的使用方法却不同,并且在以后的版本中会删除该工具。
因为innobackupex在后续版本中已经不存在。因此本文将会主要介绍xtrabackup的备份恢复方法和原理。
2. xtrabackup 备份和恢复原理
对于xtrabackup备份和恢复数据的过程总体分为3个阶段:
- 备份(backup)
- 准备(prepare)
- 恢复(copy-back 或move-back)
2.1 备份阶段(backup)
对于MySQL的备份,在大部分的情况下需要完成以下两种类型的数据的备份:
- innodb 存储引擎数据的备份。
- 非事务引擎的数据备份,例如myisam 引擎数据的备份。
在备份的过程中数据库基本处于可读写的状态,因此在这期间需要对于变化的数据进行处理,以便在备份结束时获取正确的备份数据。基于上述的考虑xtrabackup备份的过程主要包括了以下的几个步骤:
拷贝和监控redo log : 在起始时刻,xtrabackup会先获取MySQL当前时刻的LSN,同时开始拷贝redo log至xtrabackup_logfile文件中。因为在备份的过程中数据库基本处于可读写的状态下,因此redo log会不断的变化,将导致初始拷贝的redo log和MySQL当前的redo log不一致。所以在xtrabackup后台,还会启动另外的一个进程持续监控redo log文件的变化。如果监控到文件发生变化,则将其写入到xtrabackup_logfile中。这个进程会一直存在并执行监控redo log的变化,直到备份将结束为止。
拷贝innodb相关文件:拷贝包括ibdata1(共享表空间)和*.idb(如果开启了独立表空间的话)相关的文件。
加备份锁:因为非innodb表没有redo log可供拷贝,所以在备份非innodb表之前需要对数据库加锁,以防止在备份过程中数据被修改。在这里需要先简单的介绍下备份锁的概念。在各种备份工具备份数据库的过程中,为了获取一致性备份(binlog位置与数据匹配),需要在备份的过程中加上备份锁。在MySQL中会使用FLUSH TABLES WITH READ LOCK简称(FTWRL)来获取一致性备份。FTWRL会执行如下的几个操作(更具体的介绍和相关原理可以参见FLUSH TABLE WITH READ LOCK详解):
- 上全局读锁(lock_global_read_lock):阻塞所有的更新操作。
- 清理表缓存(close_cached_tables):关闭表缓存。
- 上全局COMMIT锁(make_global_read_lock_block_commit):阻塞活跃的事务提交。
FTWRL的操作中会阻塞包括innodb在内的所有存储引擎的更新操作。在FTWRL执行的过程中,整个数据库相当于只读模式。可见如果在线上数据库中(尤其在承担线上读写业务的数据库下),使用FTWRL可能会导致线上数据库长时间陷入不可写入的状态。对于这个问题percona版本的MySQL做出了优化,将FTWRL 分为了几个部分:
- lock table for backup : 这个锁会阻塞所有对非事务表的更新及所有DDL动作,但是innodb表的读写可以继续执行。
- lock binlog for backup:做锁会阻止binlog更新,因此此时所有的DML操作都会被阻塞。
可以看出如果在备份的过程中,将FTWRL拆解成如上的2步操作,则在备份非事务表的过程中可以不阻塞事务表的更新。对于xtrabackup如果备份的数据库是不支持backup lock的版本,则使用FTWRL操作。而如果是支持backup lock的版本,则使用lock tables for backup获取轻量级的backup locks来替代FTWRL。
- 拷贝非innodb表文件。
- 获取binlog一致性位置:在拷贝完所有的数据之后,备份进入收尾阶段。在这里根据是否支持backup lock分为不同的操作。对于不支持backup lock的版本,直接获取binlog的一致性坐标点同时结束redo log的监控和拷贝并释放锁。而对于支持backup lock的版本,先通过lock binlog for bakcup来获取binlog日志锁,然后结束redo log的监控和拷贝,再unlock tables释放表锁,随后获取二进制日志的一致性位置坐标点,最后unlock binlog释放binlog日志锁。
- 结束备份退出。
2.2 准备阶段(prepare)
在恢复备份之前需要对数据进行一些处理,在xtrabackup中称之prepare。这个步骤的主要工作就是将之前记录的redo log应用到innodb的数据中,使得innodb中的数据最终和备份结束的时刻一致。这个步骤不需要在有MySQL的机器上运行,xtrabackup自身实现了一个简化版本的innodb引擎,通过它完成redo log的应用。
2.3 恢复(copy-back 或move-back)
在最后一步,xtrabackup会将数据copy 或者move (如果DBA不打算保留备份数据)到数据库对应的目录下。同样这步也不需要MySQL启动或者存在,可以在任何机器上执行。但是要求对应的数据库目录下是空的,不存在任何的文件。
最后根据如上的叙述可以归纳总结如下:

3. xtrabackup 流式备份应用
当前对于部门的MySQL集群存在如下的痛点:
- 备份磁盘空间不足:随着线上数据的增长,大部分MySQL数据库都没有预留足够的备份空间,因此当前每次在本地备份数据都会导致磁盘空间报警。在DBA处理不及时的情况下,容易导致磁盘空间占满而影响服务。
而xtrabackup正好有流式备份的功能,能够解决当前DBA的痛点。因此本小节将主要介绍下xtrabackup的流式备份功能(stream模式)。
当前 xtrabackup支持2种方式的流式备份:
- tar格式(ps : tar 和ssh还有很多有意思的功能,具体可以参考使用tar+pigz+ssh实现大数据的高效传输 )
- xbstream格式
在测试xtrabackup备份功能之前需要先准备下实验环境。
| 机器 | IP | CPU | 磁盘 | 内存 |
|---|---|---|---|---|
| 机器1 | 192.168.100.1 | 40核 | 1.1T SSD(已使用60%) | 64G |
| 机器2 | 192.168.100.2 | 40核 | 1.1T SSD(空盘) | 64G |
需要完成的操作是从机器1备份数据到机器2,并且不占用机器1原本不多的剩余磁盘空间。为了能够使用流式备份功能,首先需要在机器2上完成如下2个步骤:
- 配置从机器1免密ssh登录机器2。
- 在机器2上建立存放备份的目录,本例中路径为/ssd/100_1_bak/
tar格式的备份可以选择使用gzip或者不压缩。在本例中分别使用如下命令完成:
xtrabackup --safe-slave-backup --slave_info --user='root' --password='XXXXXX' --backup --tables-file=./tb.txt --stream=tar | ssh root@192.168.100.2 "cat - | tar -x -C /ssd/100_1_bak/" #### tar 不压缩
xtrabackup --safe-slave-backup --slave_info --user='root' --password='XXXXXX' --backup --tables-file=./tb.txt --stream=tar |pigz | ssh -p32200 mysql@192.168.100.2 " gzip -d | tar -x -C /ssd/100_1_bak/" ### 使用tar 流 并交给 gzip 压缩传输
ps : xtrabackup没有选项只备份innodb表或者myisam表。但是可以通过选项指定备份的表。在本例中通过--tables-file选项,将需要备份的innodb表写入tb.txt文件中进行备份。生成tb.txt的内容可以使用如下的sql语句获得:
select CONCAT(TABLE_SCHEMA, '.', TABLE_NAME) FROM information_schema.TABLES WHERE ENGINE = 'InnoDB' AND ENGINE IS NOT NULL AND TABLE_SCHEMA NOT IN ( 'mysql', 'performance_schema', 'information_schema', 'sys') ;
如果使用xbstream格式,则可以使用如下的命令:
xtrabackup --safe-slave-backup --slave_info --user='root' --password='XXXXXX' --backup --tables-file=./tb.txt --stream=xbstream | ssh -p32200 mysql@192.168.100.2 "cat - | xbstream -x -C /ssd/100_1_bak/" ### xbstream不压缩
xtrabackup --safe-slave-backup --slave_info --user='root' --password='XXXXXX' --backup --tables-file=./tb.txt --stream=xbstream --compress | ssh -p32200 mysql@192.168.100.2 "cat - | xbstream -x -C /ssd/100_1_bak/" ### 使用--compress选项压缩
4. 总结
本文主要介绍了xtrabackup备份的原理以及流式备份功能。限于本文的作者水平有限,文中的错误在所难免,恳请大家批评指正。
xtrabackup备份原理及流式备份应用的更多相关文章
- XtraBackup的备份原理与应用示例
一.XtraBackup简介与安装 XtraBackup是一款免费的在线开源数据库备份解决方案,适用于所有版本的MySQL和MariaDB.XtraBackup支持对InnoDB热备,是一款物理备份工 ...
- Percona XtraBackup 备份原理说明【转】
本文来自:http://mysql.taobao.org/monthly/2016/03/07/ 前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MyS ...
- MySQL · 物理备份 · Percona XtraBackup 备份原理
http://mysql.taobao.org/monthly/2016/03/07/ 前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据 ...
- Percona XtraBackup 备份原理
前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server 和 ...
- xtrabackup备份原理
Percona XtraBackup工作原理 Percona XtraBackup是基于InnoDB的崩溃恢复功能.复制InnoDB数据文件,导致内部不一致的数据; 但随后它对文件执行崩溃恢复,使它们 ...
- XtraBackup 备份原理
来着淘宝技术: http://mysql.taobao.org/monthly/2016/03/07/ https://github.com/alibaba/AliSQL 前言 Percona Xtr ...
- 从源码分析 XtraBackup 的备份原理
MySQL物理备份工具,常用的有两个:MySQL Enterprise Backup 和 XtraBackup. 前者常用于MySQL企业版,后者常用于MySQL社区版.Percona Server ...
- mysqldump和xtrabackup备份原理实现说明
背景: MySQL数据库备份分为逻辑备份和物理备份两大类,犹豫到底用那种备份方式的时候先了解下它们的差异: 逻辑备份的特点是:直接生成SQL语句,在恢复的时候执行备份的SQL语句实现数据库数据的重现. ...
- mysqldump+mydumper+xtrabackup备份原理流程
mysqldump备份原理 备份的基本流程如下: 1.调用FTWRL(flush tables with read lock),全局禁止读写 2.开启快照读,获取此时的快照(仅对innodb表起作用) ...
随机推荐
- 如何制作一个Nginx镜像
1,从这里你将学到编写Dockerfile的4个重要指令RUN,EXPOSE,ADD,ENTRYPOINT2,在Dockerfile中编写拷贝文件至容器的方法3, 安装一个nginx server,并 ...
- 微信小程序开发实战-天气小程序
园龄6年8个月了,还一篇文章都没写过,惭愧! 最近周末做了个天气预报小程序,在这里整理一下开发过程和注意点,给对小程序开发感兴趣的伙伴们提供点参考. 废话不多说,先上图最终效果: 下面进入正文: 第一 ...
- ABP vNext 不使用工作单元为什么会抛出异常
一.问题 该问题经常出现在 ABP vNext 框架当中,要复现该问题十分简单,只需要你注入一个 IRepository<T,TKey> 仓储,在任意一个地方调用 IRepository& ...
- Shiro集成SSM基于URL权限管理(一)
学习了shiro之后,我们就可以说尝试把shiro加入ssm中,并做一套基于URL的权限管理. 其他的准备工作就不多说了,直接动手操作,看到效果再去理解. 表结构 执行如下,数据库名字可以自行修改,不 ...
- [Note] Visual Studio Team Service 中的项目 转到 Git
Git-tf是微软发布的一个Git工具集的补充,用来让开发人员使用git命令与TFS交互,当然现在VSTS已经直接支持git了,现在讲讲以前用了VSTS的老项目如何转到git,保留所有的change ...
- 值类型不允许赋值为Null
与引用类型不同,值类型不可能包含 null 值. 每种值类型均有一个隐式的默认构造函数来初始化该类型的默认值.有关值类型默认值的信息,请参见默认值表. bool false byte 0 char ' ...
- 【Java基础】Java中的语法糖
目录 Java中的语法糖 switch对String和枚举类的支持 对泛型的支持 包装类型的自动装箱和拆箱 变长方法参数 枚举 内部类 条件编译 断言 数值字面量 for-each try-with- ...
- 文件/大文件上传功能实现(JS+PHP)全过程
文件/大文件上传功能实现(JS+PHP) 参考博文:掘金-橙红年代 前端大文件上传 路漫漫 其修远 PHP + JS 实现大文件分割上传 本文是学习文件上传后的学习总结文章,从无到有实现文件上传功能, ...
- Flask学习之旅--Flask项目部署
一.写在前面 Flask 作为一个轻量级的 Web 框架,具有诸多优点,灵活方便,扩展性强,开发文档也很丰富.在开发调试的过程中,我们往往会使用 Flask 自带的 Web 服务器,但如果要投入到生产 ...
- java集合类之ArrayList详解
一.ArrayList源码分析 1.全局变量 (1)默认容量(主要是通过无参构造函数创建ArrayList时第一次add执行扩容操作时指定的elementData的数组容量为10) private s ...