mysql 开发进阶篇系列 45 物理备份与恢复(xtrabackup 安装,用户权限,配置)

一. 安装说明

  安装XtraBackup 2.4 版本有三种方式:

           (1) 存储库安装Percona XtraBackup(推荐)

           (2 )下载的rpm或apt包安装Percona XtraBackup。

           (3) 源代码编译和安装。
  Percona为yum (Red Hat、CentOS和Amazon Linux AMI的RPM包)和apt (Ubuntu和Debian的.deb包)提供存储库,用于Percona Server、Percona XtraBackup和Percona Toolkit等软件。存储库安装将得通过操作系统的包管理器,轻松地安装和更新软件及其依赖项。这是推荐的安装方法。

二. 安装演示(centos 7)

  使用 yum安装工具。 yum下载的默认文件包路径存放在/var/cache/yum目录下。

  步骤1:切换到root用户下,使用yum下载安装Percona 存储库,代码如下:

    [root@hsr /]# yum install http://www.percona.com/downloads/percona-release/redhat/0.1-6/percona-release-0.1-6.noarch.rpm

  完装完成后,如下图所示:
    
  步骤2: 验证yum是否安装成功。下面使用yum list输出所有yum安装的工具,并用grep来过滤,注意grep后面不要写错过滤条件。查询命令如下:

    [root@hsr /]# yum list | grep percona-xtrabackup

    
  步骤3:安装 percona-xtrabackup-24

   [root@hsr /]# yum install percona-xtrabackup-24

    

  最后简单查看xtrabackup安装路径和文档

-- 安装路径
[root@hsr /]# type xtrabackup
xtrabackup 已被哈希 (/usr/bin/xtrabackup)
-- 文档
[root@hsr /]#  xtrabackup --help
xtrabackup: recognized server arguments: --server-id=1 --log_bin=/var/lib/mysql/mysql-bin --datadir=/usr/local/mysql/data 
xtrabackup: recognized client arguments: --server-id=1 --log_bin=/var/lib/mysql/mysql-bin --datadir=/usr/local/mysql/data 
xtrabackup version 2.4.12 based on MySQL server 5.7.19 Linux (x86_64) (revision id: 170eb8c)
Open source backup tool for InnoDB and XtraDB
-- 使用方法如下:
Usage: [xtrabackup [--defaults-file=#] --backup | xtrabackup [--defaults-file=#] --prepare] [OPTIONS]
-- 默认按照以下路径读取mysql的my.cnf文件
Default options are read from the following files in the given order:
/etc/my.cnf /etc/mysql/my.cnf /usr/etc/my.cnf ~/.my.cnf
最后[OPTIONS]参数太多,这篇就不在列出。

 

三 . 用户权限

  3.1 连接服务和权限概述
    Percona XtraBackup需要能够连接到数据库服务器,并创建备份、在某些场景中进行准备和恢复备份时,在服务器的datadir上执行操作。为了做到这一点,必须满足其执行的特权和权限要求。

    无论使用xtrabackup还是innobackupex,都会涉及两个角色。调用程序的用户(系统用户)和在数据库服务器中执行操作的用户(数据库用户)。请注意,这些用户位于不同的位置,尽管他们的用户名可能相同。

  3.2 系统用户权限

    执行 innobackupex/xtrabackup 命令的Linux用户需要对mysql的datadir和保存备份的目录(mysql的环境变量tmpdir)有读写执行权限。查看datadir目录权限,使用mysql,root系统用户,查看datadir目录/usr/local/mysql/data。下图显示有读写执行权限,如果没有就需要设置。
    
    备份目录权限xtrabackup 备份选项target_dir,可以在备份时使用命令行指定选项,也可以在my.cnf中配置好target_dir,后面备份操作时再配置。

 3.3  数据库用户权限
    连接工具可以是用innobackupex或xtrabackup。innobackupex只是一个软链接指向了xtrabackup。用法一样,后面就只讲xtrabackup。innobackupex的软连接如下图所示:
    
    用于连接到服务器的数据库用户及其密码由xtrabackup—user和xtrabackup—password选项指定。这里user用户是指mysql.user表中的用户,需要一些基本的权限来执行备份过程。数据库用户需要备份表或数据库需要以下权限:

(1) RELOAD重新加载和LOCK TABLES锁定表(除非指定了-no-lock选项)二个权限,LOCK TABLES是为了在开始复制文件之前使用READ LOCK读锁, 在使用备份锁时,用于备份的锁表和用于备份的锁BINLOG需要此特权。RELOAD是为了刷新引擎日志来FLUSH TALBES刷新表。

(2) REPLICATION CLIENT复制权限,是客户端为了获得二进制日志位置。

(3) TABLESPACE表空间权限,创建表空间以导入表(参见恢复各个表)。

(4) PROCESS进程权限,是为了运行SHOW ENGINE INNODB STATUS(这是强制性的),并可选地看到所有线程运行在服务器上(见改进的嵌入式表与读锁处理)。

(5) SUPER权限,为了在复制环境中启动/停止从线程,使用XtraDB更改后的页面跟踪来进行增量备份和改进的具有读锁处理的刷新表。

(6) CREATE privilege特权 是为了创建PERCONA_SCHEMA.xtrabackup_history库和表。

(7 )INSERT privilege特权,是为了添加历史记录PERCONA_SCHEMA.xtrabackup_history 表。

(8) select privilege特权,是为了使用innobackupex—incremental-history-name或innobackupex—incremental-history-uuid,以便特性在PERCONA_SCHEMA.xtrabackup_history 表中查找innodb_to_lsn值。

 

-- 下面一个案例是:创建一个数据库用户,对于完全备份使用必需的最小特权。
mysql> CREATE USER 'bkpuser'@'localhost' IDENTIFIED BY 's3cret';
mysql> GRANT RELOAD, LOCK TABLES, PROCESS, REPLICATION CLIENT ON *.* TO
       'bkpuser'@'localhost';
mysql> FLUSH PRIVILEGES;

 

四.配置 xtrabackup
  所有的xtrabackup配置都是通过选项完成的,其行为与标准的MySQL程序选项完全相同:它们可以通过命令行指定,也可以通过/etc/my.cnf这样的文件指定。
  xtrabackup二进制文件按照顺序从任何配置文件中读取[mysqld]和[xtrabackup]部分。这样它就可以从您现有的MySQL安装中读取它的选项,例如datadir或一些InnoDB选项。如果您想要重写这些内容,只需在[xtrabackup]部分中指定它们,因为它稍后会被读取,所以它会优先。
  如果不需要,您不需要在my.cnf中添加任何配置。您可以简单地在命令行上指定选项。通常,在my.cnf文件的[xtrabackup]部分,您可能会发现唯一方便的地方是target_dir选项,它可以默认放置备份的目录。例如:

[xtrabackup]
target_dir = /data/backups/mysql/

 

posted on 2018-09-30 12:00  花阴偷移  阅读(546)  评论(0编辑  收藏  举报

导航