zoukankan      html  css  js  c++  java
  • 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/
  • 相关阅读:
    python之面向对象之类变量和实例变量
    python之面向对象之封装
    python之shutil模块
    利用python实现冒泡排序
    利用python实现二分法和斐波那契序列
    thinkphp input
    从右向左
    全局修改composer源地址
    Git忽略规则及.gitignore规则不生效的解决办法
    mysql主从数据库不同步的2种解决方法 (转载)
  • 原文地址:https://www.cnblogs.com/MrHSR/p/9727916.html
Copyright © 2011-2022 走看看