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-
最后简单查看xtrabackup安装路径和文档
-- 安装路径
[root@hsr /]# type xtrabackup
xtrabackup 已被哈希 (/usr/bin/xtrabackup)
-- 文档
[root@hsr /]# xtrabackup --help
xtrabackup: recognized server arguments: --server-id= --log_bin=/var/lib/mysql/mysql-bin --datadir=/usr/local/mysql/data
xtrabackup: recognized client arguments: --server-id= --log_bin=/var/lib/mysql/mysql-bin --datadir=/usr/local/mysql/data
xtrabackup version 2.4. based on MySQL server 5.7. 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/
mysql 开发进阶篇系列 45 物理备份与恢复(xtrabackup 安装,用户权限,配置)的更多相关文章
- mysql 开发进阶篇系列 47 物理备份与恢复(xtrabackup 的完全备份恢复,恢复后重启失败总结)
一. 完全备份恢复说明 xtrabackup二进制文件有一个xtrabackup --copy-back选项,它将备份复制到服务器的datadir目录下.下面是通过 --target-dir 指定完全 ...
- mysql 开发进阶篇系列 46 物理备份与恢复( xtrabackup的 选项说明,增加备份用户,完全备份案例)
一. xtrabackup 选项说明 在操作xtrabackup备份与恢复之前,先看下该工具的选项,下面记录了xtrabackup二进制文件的部分命令行选项,后期把常用的选项在补上.点击查看xtrab ...
- mysql 开发进阶篇系列 48 物理备份与恢复(xtrabackup 的增量备份与恢复,以及备份总结)
一.增量备份概述 xtrabackup 和innobackupex 二个工具都支持增量备份,这意味着能复制自上次备份以来更改的数据.可以在每个完整备份之间执行许多增量备份,因此,您可以设置一个备份 ...
- mysql 开发进阶篇系列 44 物理备份与恢复( 热备份xtrabackup 工具介绍)
一.概述 物理备份和恢复又分为冷备份和热备份.与逻辑备份相比,它最大优点是备份和恢复的速度更快.因为物理备份的原理都是基于文件的cp. 1.1 冷备份 冷备份就是停掉数据库服务.这种物理备份一般很少使 ...
- mysql 开发进阶篇系列 42 逻辑备份与恢复(mysqldump 的完全恢复)
一.概述 在作何数据库里,备份与恢复都是非常重要的.好的备份方法和备份策略将会使得数据库中的数据更加高效和安全.对于DBA来说,进行备份或恢复操作时要考虑的因素大概有如下: (1) 确定要备份的表的存 ...
- mysql 开发进阶篇系列 43 逻辑备份与恢复(mysqldump 的基于时间和位置的不完全恢复)
一. 概述 在上篇讲到了逻辑备份,使用mysqldump工具来备份一个库,并使用完全恢复还原了数据库.在结尾也讲到了误操作是不能用完全恢复的.解决办法是:我们需要恢复到误操作之前的状态,然后跳过误操作 ...
- mysql 开发进阶篇系列 30 数据库二进制包(安装指定路径,目录介绍)
一. 指定路径 在上一篇里,二进制包解压后,全部放入在/usr/local/mysql目录下,在安装时指定了基础目录和数据目录, --basedir=/usr/local/mysql --datadi ...
- mysql 开发进阶篇系列 29 数据库二进制包安装
概述 对于二进制安装,优点是可以安装到任何路径下,灵活性好,一台服务器可以安装多个mysql.缺点是已经绎过编译,性能不如源码编译得好,不能灵活定制编译参数.如果用户即不想安装最简单却不够灵活的RPM ...
- mysql 开发进阶篇系列 28 数据库二进制包安装(centos系统准备)
1. centos 7安装工作 对于mysql二进制安装,我这里在使用一台新的centos系统.准备好VMware,Xftp-6.0, Xshell-6.0.在VMware中网络使用桥接模式,分配20 ...
随机推荐
- 别人的Linux私房菜(17)进程管理与SELinux初探
程序在磁盘中,通过用户的执行触发.触发事件时,加载到内存,系统将它定义成进程,给予进程PID,根据触发的用户和属性,给予PID合适的权限. PID和登陆者的UID/GID有关.父进程衍生出来的进程为子 ...
- javabean转换为map对象
在调用第三方接口发现对方使用map进行接收(不包括秘钥等),将bean类属性转换为map,直接贴代码: /** * JavaBean对象转化成Map对象 * * @param javaBean */p ...
- PE文件常用结构体
Dos头结构: typedef struct _IMAGE_DOS_HEADER { // DOS .EXE header WORD e_magic; // Magic number WORD e_c ...
- influence maximization 第二弹
Robust Influence Maximization 首先简要介绍一下这个问题:在一个社交网络图中寻找固定数量的节点,使得这些节点对所有节点的影响值尽可能的大.先对这个问题给出形式化的定义:给一 ...
- Java实现对文本文件MD5加密并ftp传送到远程主机目录
需求描述: 客户出完账之后需要把出账的数据以文本文件的方式传送给收入管理系统,客户以前是通过本地的一个工具软件上传的,由于安全监管的原因,不允许在本地使用工具上传,因此客户希望我们在已经上线使用的系统 ...
- window7 32位部署django
window7 32位安装环境,所有的软件都用32位的,如果你想要用64位的软件需要操作系统和下面的相关软件都换成64位,我是在虚拟机上装了win7 32版做的测试. 软件下载地址: python2. ...
- DevOps最佳工具集实践
在列出DevOps 工具链之前,介绍一下什么是DevOps,虽然DevOps这个概念现在还没有标准的定义,但我们可以追溯一下其过去九年的历史发展过程(从2009年-2017年),列出几个相对明确又有所 ...
- 解决jenkins控制台中文乱码问题
1,进入[系统管理]->[系统设置]->全局属性:KEY: LANG; VALUE:zh.CH.UTF-8 2,修改Jenkins.xml文件 在Jenkins安装目录下找到jenkins ...
- Android P正式版即将到来:后台应用保活、消息推送的真正噩梦
1.前言 对于广大Android开发者来说,Android O(即Android 8.0)还没玩热,Andriod P(即Andriod 9.0)又要来了. 下图上谷歌官方公布的Android P ...
- 网络编程懒人入门(六):深入浅出,全面理解HTTP协议
本文引用了自简书作者“涤生_Woo”的文章,内容有删减,感谢原作者的分享. 1.前言 HTTP(全称超文本传输协议,英文全称HyperText Transfer Protocol)是互联网上应用最为广 ...