您的位置:首页 > 其它

Innobackupex 单表备份

2013-10-31 18:37 288 查看
Innobackupex 单表备份

一、使用Xtrabackup对数据库进行部分备份
Xtrabackup也可以实现部分备份,即只备份某个或某些指定的数据库或某数据库中的某个或某些表。但要使用此功能,必须启用innodb_file_per_table选项,即每张表保存为一个独立的文件。同时,其也不支持--stream选项,即不支持将数据通过管道传输给其它程序进行处理。
此外,还原部分备份跟还原全部数据的备份也有所不同,即你不能通过简单地将prepared的部分备份使用--copy-back选项直接复制回数据目录,而是要通过导入表的方向来实现还原。当然,有些情况下,部分备份也可以直接通过--copy-back进行还原,但这种方式还原而来的数据多数会产生数据不一致的问题,因此,无论如何不推荐使用这种方式。

(1)创建部分备份

创建部分备份的方式有三种:正则表达式(--include), 枚举表文件(--tables-file)和列出要备份的数据库(--databases)。

(a)使用--include
使用--include时,要求为其指定要备份的表的完整名称,即形如databasename.tablename,如:
# innobackupex --include='^kk[.]k_4' /data/backup/kk-include
Note: 会匹配所有的库

(b)使用--tables-file
此选项的参数需要是一个文件名,此文件中每行包含一个要备份的表的完整名称;如:
# echo -e 'kk.k_4\nmageedu.tb2' > /tmp/tables.txt
# innobackupex --tables-file=/tmp/tables.txt /data/backup/kk-file

(c)使用--databases
此选项接受的参数为数据名,如果要指定多个数据库,彼此间需要以空格隔开;同时,在指定某数据库时,也可以只指定其中的某张表。此外,此选项也可以接受一个文件为参数,文件中每一行为一个要备份的对象。如:
# innobackupex --databases='mageedu.tb1 testdb" /data/backup/kk-database

(2)整理(preparing)部分备份
prepare部分备份的过程类似于导出表的过程,要使用--export选项进行:
# innobackupex --apply-log --export /data/backup/kk-database

此命令执行过程中,innobackupex会调用xtrabackup命令从数据字典中移除缺失的表,因此,会显示出许多关于“表不存在”类的警告信息。同时,也会显示出为备份文件中存在的表创建.exp文件的相关信息。

(3)还原部分备份
还原部分备份的过程跟导入表的过程相同(即下面第二部分的导入或导出单张表)。当然,也可以通过直接复制prepared状态的备份至数据目录中实现还原,不过此时要求数据目录处于一致状态。

i.e.
1) innobackupex --no-timestamp --databases="fei" /data/backup/fei/
2) innobackupex --apply-log --use-memory=4G --export /data/backup/fei/
3) rm -rf /var/lib/mysql/fei

cp -rf /data/backup/fei/fei /var/lib/mysql/
chown -R mysql.mysql /var/lib/mysql/
/etc/init.d/mysql start

二、导入或导出单张表

默认情况下,InnoDB表不能通过直接复制表文件的方式在mysql服务器之间进行移植,即便使用了innodb_file_per_table选项。而使用Xtrabackup工具可以实现此种功能,不过,此时需要“导出”表的mysql服务器启用了innodb_file_per_table选项(严格来说,是要“导出”的表在其创建之前,mysql服务器就启用了innodb_file_per_table选项),并且“导入”表的服务器同时启用了innodb_file_per_table和innodb_expand_import选项。innodb_expand_import选项,Mysql 5.5已经更名为innodb_import_table_from_xtrabackup。

(1)“导出”表
导出表是在备份的prepare阶段进行的,因此,一旦完全备份完成,就可以在preparef过程中通过--export选项将某表导出了:
# innobackupex --apply-log --use-memory=4G --export /data/backup/kk-database/

此命令会为每个innodb表的表空间创建一个以.exp结尾的文件,这些以.exp结尾的文件则可以用于导入至其它服务器。

(2)“导入”表
要在mysql服务器上导入来自于其它服务器的某innodb表,需要先在当前服务器上创建一个跟原表表结构一致的表,而后才能实现将表导入:
CREATE TABLE mytable (...) ENGINE=InnoDB;

然后将此表的表空间删除:
mysql> ALTER TABLE kk.hh DISCARD TABLESPACE;
接下来,将来自于“导出”表的服务器的mytable表的mytable.ibd和mytable.exp文件复制到当前服务器的数据目录,然后使用如下命令将其“导入”:
mysql> ALTER TABLE kk.hh IMPORT TABLESPACE;

i.e.
前提准备

vim /etc/mysql/my.cnf
innodb_file_per_table = 1
innodb_import_table_from_xtrabackup = 1 or innodb_expand_import = 1
/etc/init.d/mysql restart 重启mysql
1) 备份
mysql> use kk;

mysql> create table hh engine=Innodb as select * from information_schema.tables;
innobackupex --no-timestamp --databases="kk.hh" /data/backup/kk-database/
mysqldump -uroot -p -d kk > createtab.sql 导出表结构供导入表的时候使用

2) 准备

innobackupex --apply-log --use-memory=4G --export /data/backup/kk-database/
3) 恢复

mysql> CREATE TABLE `hh` (
`TABLE_CATALOG` varchar(512) CHARACTER SET utf8 NOT NULL DEFAULT '',
`TABLE_SCHEMA` varchar(64) CHARACTER SET utf8 NOT NULL DEFAULT '',
`TABLE_NAME` varchar(64) CHARACTER SET utf8 NOT NULL DEFAULT '',
`TABLE_TYPE` varchar(64) CHARACTER SET utf8 NOT NULL DEFAULT '',
`ENGINE` varchar(64) CHARACTER SET utf8 DEFAULT NULL,
`VERSION` bigint(21) unsigned DEFAULT NULL,
`ROW_FORMAT` varchar(10) CHARACTER SET utf8 DEFAULT NULL,
`TABLE_ROWS` bigint(21) unsigned DEFAULT NULL,
`AVG_ROW_LENGTH` bigint(21) unsigned DEFAULT NULL,
`DATA_LENGTH` bigint(21) unsigned DEFAULT NULL,
`MAX_DATA_LENGTH` bigint(21) unsigned DEFAULT NULL,
`INDEX_LENGTH` bigint(21) unsigned DEFAULT NULL,
`DATA_FREE` bigint(21) unsigned DEFAULT NULL,
`AUTO_INCREMENT` bigint(21) unsigned DEFAULT NULL,
`CREATE_TIME` datetime DEFAULT NULL,
`UPDATE_TIME` datetime DEFAULT NULL,
`CHECK_TIME` datetime DEFAULT NULL,
`TABLE_COLLATION` varchar(32) CHARACTER SET utf8 DEFAULT NULL,
`CHECKSUM` bigint(21) unsigned DEFAULT NULL,
`CREATE_OPTIONS` varchar(255) CHARACTER SET utf8 DEFAULT NULL,
`TABLE_COMMENT` varchar(2048) CHARACTER SET utf8 NOT NULL DEFAULT ''
) ENGINE=InnoDB ;

mysql> ALTER TABLE kk.hh DISCARD TABLESPACE;
cp kk-database/kk/hh.exp /var/lib/mysql/kk/ && cp kk-database/kk/hh.ibd /var/lib/mysql/kk/
chown -R /var/lib/mysql/kk

mysql> ALTER TABLE kk.hh IMPORT TABLESPACE;

Copy single DB:

To take a backup of a single database you just need to use --include. --databases has no effect for InnoDB files. For example, to backup only the "test" database you can do the following:

innobackupex --include="^test\." /tmp/

This kind of backups are called "partial backups" and the restore process is more complicated. First before taking the backup you need to have innodb_file_per_table enabled.

During the preparation stage you need to use --export --apply-log. That will create .exp files that will allow you to recover tables one by one. Then you will need to import tables one by one following this procedure:

http://www.percona.com/doc/percona-x...porting-tables

You cannot just move the backup to the datadir of mysql if you are backing up a single database, because the shared tablespace (ibdata) contains information from all the InnoDB tables. If you restore a partial backup without following the restore procedure of that link you can lose the access to the access to all other databases.

参考文档:http://blog.chinaunix.net/uid-23491661-id-3166863.html http://www.percona.com/doc/percona-xtrabackup/2.1/innobackupex/innobackupex_script.html
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息