小明在某次操作中,误操作导致误删除了某个表,需要立即进行数据恢复。

如果是数据量较小的实例,并且有备份,即便是全备,做一次全量恢复,然后单表导出导入,虽然麻烦一点,却也花不了多少时间;如果是数据量大的实例,但分表备份的话,那么直接导入的话也是可以的。

现实中往往是比较残酷的,我们很可能是全量备份,加上增量备份的备份策略,那么这样的代价就比较大了。

全量备份恢复,再加上 N 个增量的恢复,上百 G 甚至上 T 的数据,在等数据恢复、拷贝数据库、追同步完成的过程中,估计你后面已经站满了领导/(ㄒoㄒ)/~~

本文主要介绍利用 XtraBackup 备份工具来实现单表快速恢复,在紧急数据恢复场景下,用最短的时间来恢复数据,最大程度降低损失。

在 MySQL 5.6 之前,对基于 InnoDB 存储引擎的表,即便开启 innodb_file_per_table 选项,也是无法通过复制数据文件来达到在不同实例之间复制表的目的的。

但是,通过 Percona XtraBackup 可以导出任意基于 InnoDB 存储引擎,并且使用独立表空间的表,还可以把它们导入到 启用了 XtraDB 存储引擎的 Percona Server 或者 MySQL 5.6 中(源库不要求必须是使用 XtraDB 存储引擎或者 MySQL 5.6,但目标库要求必须)。这只适用于使用独立 .ibd 文件的表,不能导出没有 .ibd 文件的表。

注意:

如果你使用的 Percona Server 版本早于 5.5.10-20.1,变量 innodb_expand_import 应该换成 innodb_import_table_from_xtrabackup

导出表(Exporting tables)

导出表是在准备阶段完成,而不是在创建备份的时候。一旦创建完成了一个备份,使用 

网友评论