(1)备份介绍

(2)下载安装xtrabackup

官网:https://www.percona.com/downloads/XtraBackup/LATEST/

我选择yum安装,centos版本7

wget http://www.percona.com/downloads/percona-release/redhat/0.1-4/\
percona-release-0.1-4.noarch.rpm
rpm -ivH percona-release-0.1-4.noarch.rpm
yum install percona-xtrabackup-24 -y

(3)完全备份与恢复

1)完全备份

  • 创建备份账户
mysql> grant reload,process,lock tables,replication client on *.* to backup@localhost identified by 'backup';
mysql> flush privileges;
  • 创建完全备份目录
mkdir /mysql/backup-full -pv
  • 完全备份
方式一:innobackupex --user=backup --password=backup --host=127.0.0.1 /mysql/backup-full/
方式二:innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock /mysql/backup-full/
生成目录:/mysql/backup-full/2018-04-24_11-16-17/

2)完全备份恢复

  • 停止服务删除数据目录
systemctl stop mysqld
rm -rf /data/mydata/*
  • 恢复
innobackupex --apply-log /mysql/backup-full/2018-04-24_11-16-17/
innobackupex --copy-back /mysql/backup-full/2018-04-24_11-16-17/
  • 授权与恢复
chown -R mysql.mysql /data/mydata/
systemctl start mysqld

(4)增量备份与恢复

注意:增量备份目录我这里放在/mysql/目录下,完全备份目录放在/mysql/backup-full/目录下

1)完全增量备份

注意:增量备份目录我这里放在/mysql/目录下,完全备份目录放在/mysql/backup-full/目录下

  • 准备环境
mysql> create database testdb;
mysql> create table testdb.test(id int);
mysql> insert into testdb.test values(1);
  • 完全备份:4月24日
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock  /mysql/backup-full/
目录下生成:/mysql/backup-full/2018-04-24_12-15-09/
  • 第一次增量备份:4月25日增量备份1

    修改时间为4月25日:date -s "20180425"
插入数据:mysql> insert into testdb.test values(2);

innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完全备份

基准是完全备份:/mysql/backup-full/2018-04-24_12-15-09/
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=/mysql/backup-full/2018-04-24_12-15-09/

生成增量备份目录:/mysql/2018-04-25_00-01-14/

  • 第二次增量备份:4月26日增量备份2

    修改时间为4月26日:date -s "20180426"
再次插入数据:mysql> insert into testdb.test values(3);

innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=上一次增量备份

基准是上一次增量备份:/mysql/2018-04-25_00-01-14/
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql --incremental-basedir=/mysql/2018-04-25_00-01-14/

生成增量备份目录:/mysql/2018-04-26_00-00-59/

2)增量恢复

  • 停止服务删除数据
systemctl stop mysqld
rm -rf /data/mydata/*
  • 数据恢复

    innobackupex --apply-log --redo-only 完整备份目录

    innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=第一次增量备份目录

    innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=第二次增量备份目录

    innobackupex --copy-back 完整备份
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/ --incremental-dir=/mysql/2018-04-25_00-01-14/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_12-15-09/ --incremental-dir=/mysql/2018-04-26_00-00-59/
innobackupex --copy-back /mysql/backup-full/2018-04-24_12-15-09/
  • 目录授权与启动mysql
chown -R mysql.mysql /data/mydata/
systemctl start mysqld

(5)差异备份恢复

注意:差异备份的基准永远根据上一次完全备份

1)差异备份

  • 准备环境
mysql> create database testdb;
mysql> create table testdb.test(id int);
mysql> insert into testdb.test values(1);
  • 完整备份:20180424(date -s "20180424")
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock  /mysql/backup-full/
生成目录:ll /mysql/backup-full/2018-04-24_00-00-08/
  • 插入一条数据
mysql> insert into testdb.test values(2);
  • 差异备份1:20180425(date -s "20180425")

    innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完整备份目录
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/  --incremental-basedir=/mysql/backup-full/2018-04-24_00-00-08/
生成目录:/mysql/2018-04-25_00-01-51/
  • 插入一条数据
mysql> insert into testdb.test values(3);
  • 差异备份2:20180426(date -s "20180426")

    innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/ --incremental-basedir=完整备份目录
innobackupex --defaults-file=/etc/my.cnf --user=backup --password=backup --socket=/tmp/mysql.sock --incremental /mysql/  --incremental-basedir=/mysql/backup-full/2018-04-24_00-00-08/
生成目录:/mysql/2018-04-26_00-00-15/

2)差异备份恢复

  • 停止数据和删除数据目录
systemctl stop mysqld
rm -rf /data/mydata/*
  • 数据恢复

    innobackupex --apply-log --redo-only 完整备份目录

    innobackupex --apply-log --redo-only 完整备份目录 --incremental-dir=某个差异备份目录

    innobackupex --copy-back 完整备份目录
innobackupex --apply-log --redo-only  /mysql/backup-full/2018-04-24_00-00-08/
innobackupex --apply-log --redo-only /mysql/backup-full/2018-04-24_00-00-08/ --incremental-dir=/mysql/2018-04-26_00-00-15/
innobackupex --copy-back /mysql/backup-full/2018-04-24_00-00-08/
  • 目录授权与启动数据库
systemctl start mysqld
chown -R mysql.mysql /data/mydata/
systemctl start mysqld

(十一)mysql备份之物理备份xtrabackup的更多相关文章

  1. Mysql备份与恢复(1)---物理备份

    数据库对企业来说最重要的莫过于其中的数据,所以做好数据库的备份是一个不可或缺的工作.数据库及时备份可以帮助我们在数据库出现异常宕机时及时的使用备份数据进行恢复工作,将因为数据库宕机产生的影响降低到最小 ...

  2. 说明Oracle数据库逻辑备份和物理备份的方式。

    说明Oracle数据库逻辑备份和物理备份的方式. 解答:Oracle备份包括逻辑备份和物理备份. 1).逻辑备份 数据库的逻辑备份包含读一个数据库记录集和将记录集写入文件. a.输出(Export)输 ...

  3. ORACLE数据库的备份分为物理备份和逻辑备份两种。

    物理备份是将实际组成数据库的操作系统文件从一处拷贝到另一处的备份过程,通常是从磁盘到磁带.可以使用 Oracle 的恢复管理器(Recovery Manager,RMAN)或操作系统命令进行数据库的物 ...

  4. (4.15)mysql备份还原——物理备份之XtraBackup的下载与安装

    关键词:mysql物理备份,XtraBackup,XtraBackup安装,XtraBackup下载 实践链接:https://www.cnblogs.com/gered/p/11147193.htm ...

  5. (4.16)mysql备份还原——物理备份之XtraBackup实践

    关键词:XtraBackup实践,物理备份,xtrabackup备份,innobackupex备份 [1]如何使用? [3]系列:innobackupex --help |more [4]系列:xtr ...

  6. MYSQL的备份与恢复--物理备份xrabackup

    目录 1.数据库完整备份与恢复 (1)环境准备 (2)完全备份恢复流程 2.数据库增量备份与恢复 (1)增量和差异概述 (2)增量备份和恢复 3.数据库差异备份与恢复 4.简单命令进行物理备份 5.实 ...

  7. mysqldump 逻辑备份和物理备份

    逻辑备份 逻辑备份是备份sql语句,在恢复的时候执行备份的sql语句实现数据库数据的重现. 工具:mysqldump 特点: 1.可移植性比较强 2.备份和恢复的花费时间长,不适用于大型业务系统 物理 ...

  8. mysql 开发进阶篇系列 48 物理备份与恢复(xtrabackup 的增量备份与恢复,以及备份总结)

    一.增量备份概述 xtrabackup  和innobackupex  二个工具都支持增量备份,这意味着能复制自上次备份以来更改的数据.可以在每个完整备份之间执行许多增量备份,因此,您可以设置一个备份 ...

  9. MySQL 物理备份工具-xtrabackup

    安装 wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo yum -y install perl ...

随机推荐

  1. TCP的挥手协议和握手协议2

    三次握手协议:三次握手协议的主要过程是交互彼此之间的初始序列号,如果没有确认的ACK帧可以么?肯定是可以的 client A -------> server B client A 发送了自己的初 ...

  2. [LeetCode] 70. Climbing Stairs(斐波那契数列)

    [思路] a.因为两种跳法,1阶或者2阶,那么假定第一次跳的是一阶,那么剩下的是n-1个台阶,跳法是f(n-1); b.假定第一次跳的是2阶,那么剩下的是n-2个台阶,跳法是f(n-2) c.由a.b ...

  3. Struts1之编码问题

    <%@ page contentType="text/html;charset=UTF-8" language="java" pageEncoding=& ...

  4. ashx文件和aspx

    ashx文件和aspx文件有什么不同? 我们先新建一个ashx文件看看: <%@ WebHandler Language="C#" Class="Handler&q ...

  5. ARC075 E.Meaningful Mean(树状数组)

    题目大意:给定n和k,问an中有多少子区间的平均值大于等于k 很巧妙的一个式子,就是如果一个区间[l, r]满足条件 那么则有 sum[r] - sum[l-1] >= (r-l+1)*k 整理 ...

  6. SNMP协议介绍

    SNMP协议介绍 一.什么是SNMP SNMP:“简单网络管理协议”,用于网络管理的协议.SNMP用于网络设备的管理.SNMP的工作方式:管理员需要向设备获取数据,所以SNMP提供了 “读”操作:管理 ...

  7. TYVJ 1035 / codevs 2171 棋盘覆盖

    Problem Description 给定一个n * m的棋盘,已知某些各自禁止放置,求最多往棋盘上放多少长度为2宽度为1的骨牌(骨牌不重叠) Input 第一行为n,m(表示有m个删除的格子)第二 ...

  8. MySQL的字符集小结

    正确了解MySQL的字符集问题,能够从根本上解决乱码的困扰. 首先,MySQL的字符集问题主要是两个概念,一个是Character Sets,一个是Collations,前者是字符内容及编码,后者是对 ...

  9. 编写一个 Chrome 浏览器扩展程序

    浏览器扩展允许我们编写程序来实现对浏览器元素(书签.导航等)以及对网页元素的交互, 甚至从 web 服务器获取数据,以 Chrome 浏览器扩展为例,扩展文件包括: 一个manifest文件(主文件, ...

  10. C# 序列化理解 1(转)

    序列化又称串行化,是.NET运行时环境用来支持用户定义类型的流化的机制.其目的是以某种存储形成使自定义对象持久化,或者将这种对象从一个地方传输到另一个地方.    .NET框架提供了两种串行化的方式: ...