zoukankan      html  css  js  c++  java
  • Percona XtraBackup的部分备份与恢复/单库备份/单表备份/指定库备份/指定表备份

    本文是翻译的Percona XtraBackup 2.2版的官方文档,原文地址在此:https://www.percona.com/doc/percona-xtrabackup/2.2/innobackupex/partial_backups_innobackupex.html,以下是译文。

    原官方文档没有如何恢复的方法,恢复部分是我自己加的。

    -----------------------------------------------------------这是一条分割线-----------------------------------------------------------

    Percona XtraBackup的功能之一“部分备份(partial backups)”,即让用户可以备份指定的表或数据库。要注意的是:你希望备份的表必须是在独立的表空间中,即该表在创建以前,你的MySQL开启了innodb_file_per_table设置。

    还一点要注意的是:不要将prepared backup备份的东西拷贝回去。部分备份使用的是导入表(importing the tables),而不是全库备份的--copy-back参数。尽管有时简单的拷贝备份文件可以成功,但是这种方法很容易导致数据库的不一致,因此不推荐大家这么做。

    创建部分备份(Creating Partial Backups)

    部分备份共有三种方式,分别是:1. 用正则表达式表示要备份的库名及表名(参数为--include);2. 将要备份的表名或库名都写在一个文本文件中(参数为--tables-file)以及 3. 将要备份表名或库名完整的写在命令行中(参数为:--databases)。(译者注:不管你备份哪个库或是哪张表,强烈推荐把mysql库也一起备份,恢复的时候要用。)

    方式一:使用--include参数

    这种方式通过正则表达式来匹配数据库名和表名,你需要写完整的数据库名及表名,如果数据库有用户名密码请使用--user和--password指定相关信息。,格式如下:databasename.tablename。下面是一个例子:

     

    [plain] view plain copy
     
    1. $ innobackupex --include='^mydatabase[.]mytable' /path/to/backup --user=backup --password=backup  


    上面的方式会和其他使用innobackupex命令的备份方式一样,创建一个时间戳命名的文件夹,不同的是,最终只包括那些正则表达式匹配的表。

     

    要注意的是,这个命令最后会传给xtrabackup --tables命令执行,并且会为每个数据库(包括不需要备份的数据库)创建一个对应的文件夹。

    方式二:使用--tables-file参数

    这种方式是将所有要备份的完整表名都写在一个文本文件中,每行一个完整表名,然后程序读取这个文本文件进行备份。完整表名即:databasename.tablename。如果数据库有用户名密码请使用--user和--password指定相关信息。下面是一个例子:

     

    [plain] view plain copy
     
    1. $ echo "mydatabase.mytable" > /tmp/tables.txt  
    2. $ innobackupex --tables-file=/tmp/tables.txt /path/to/backup --user=backup --password=backup  


    上面的方式会和其他使用innobackupex命令的备份方式一样,创建一个时间戳命名的文件夹,不同的是,最终只包括那些文件中指定的表名。

     

    这个命令最后会传给xtrabackup --tables-file命令执行,而不是--tables,因此这个命令只会创建那些需要备份的数据库文件夹。

    方式三:使用--databases参数

    使用这种方式,用户既可以将所有要备份的数据库名和完整表名都写在一起,以空格分隔,也可以将数据库名、完整表名写在一个文件中,每行一个,如果数据库有用户名密码请使用--user和--password指定相关信息。下面是一个例子。

     

    [plain] view plain copy
     
    1. $ innobackupex --databases="mydatabase.mytable mysql" /path/to/backup --user=backup --password=backup  


    上面的方式会和其他使用innobackupex命令的备份方式一样,创建一个时间戳命名的文件夹,最终结果将包括mydatabase数据库中的mytable表,以及整个完整的mysql数据库。

     

    准备部分备份(Preparing Partial Backups)

    执行preparing partial backups,与恢复独立的表(Restoring Individual Tables)很类似:使用--apply-log和--export参数,并包含上一步生成的时间戳文件夹,如下:

     

    [plain] view plain copy
     
    1. $ innobackupex --apply-log --export /path/to/backup/2015-11-09_16-33-58  


    执行命令的时候,对于那些不需要备份的表,会出现表不存在的提示。不用担心,这是正常现象。下面是可能出现的错误提示:

     

     

    [plain] view plain copy
     
    1. 111225  0:54:06  InnoDB: Error: table 'mydatabase/mytablenotincludedinpartialb'  
    2. InnoDB: in InnoDB data dictionary has tablespace id 6,  
    3. InnoDB: but tablespace with that id or name does not exist. It will be removed from data dictionary.  


    同时,你还会看到系统生成对要备份的表创建导出文件的提示,信息如下:

     

     

    [plain] view plain copy
     
    1. xtrabackup: export option is specified.  
    2. xtrabackup: export metadata of table 'employees/departments' to file `.//departments.exp` (2 indexes)  
    3. xtrabackup:     name=PRIMARY, id.low=80, page=3  
    4. xtrabackup:     name=dept_name, id.low=81, page=4  


    注意,你能够对已经执行过准备备份(already-prepared backup)的文件执行带有--export和--apply-log参数的命令,来生成.exp文件。

     

    最终,记得观察下面的输出,已确定准备备份工作结束。

     

    [plain] view plain copy
     
    1. 111225 00:54:18  innobackupex: completed OK!  

     

     

    恢复部分被备份(Restoring Partial Backups)

    方法一:恢复数据操作可以参见恢复独立的表(Restoring Individual Tables)这一小节。(这种方法本人试验没成功,推荐使用方法二)

    方法二:

    [plain] view plain copy
     

    1. 停止MySQL:service mysql stop  

    2. 将/var/lib/mysql下面的所有文件全部删除:rm /var/lib/mysql/* -rf(如果前面没有备份mysql数据库, 那么在删除数据文件后要重建mysql系统表,重建命令是sudo mysql_install_db --user=mysql,但重建会导致原有用户信息全部丢失)  

    3. 将第二步准备过的文件拷贝到/var/lib/mysql下:cp /usr/local/backup/2015-11-09_16-33-58/* /var/lib/mysql -rf  

    4. 给文件赋权:chown -R mysql:mysql /var/lib/mysql/  

    5. 启动MySQL:service mysql start  

  • 相关阅读:
    为archlinux安装mplayer
    linux与windows的文本文件之间的转换
    有关git的换行符的处理问题
    让git忽略文件模式的改变
    linux更新系统之后,删除多余的开机启动项
    关于centos更新后virtualbox无法使用的问题
    SQL 中逻辑运算符的优先级
    archlinux安装输入法需要的包及archlinux无法使用输入法的解决
    从前有座山,山里有座庙
    批量修改照片名称的shell脚本
  • 原文地址:https://www.cnblogs.com/conanwang/p/5957192.html
Copyright © 2011-2022 走看看