mysql物理备份工具Xtrabackup安装配置

1    Xtrabackup工具介绍

Xtrabackup是一个对InnoDB做物理数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具InnoDB Hotbackup的一个很好的替代品。

Xtrabackup有两个主要的工具:xtrabackup、innobackupex

(1)xtrabackup只能备份InnoDB和XtraDB两种数据表,而不能备份MyISAM数据表。

(2)innobackupex是用来备份非InnoDB表的,同时会调用xtrabackup命令来备份InnoDB表,还会和mysql server发送命令进行交会,如加读锁、获取位点等。简单来说,innobackupex在xtrabackup之上做了一层封装。

一般情况下,我们是希望能备份MyISAM表的,虽然我们可能自己不用MyISAM表,但是mysql库下的系统表示MyISAM的,因此备份基本都通过innobackupex命令进行;另外一个原因是我们可能需要保存位点信息。

2   XtraBackup备份原理

XtraBackup基于InnoDB的crash-recovery功能,它会复制InnoDB的data file,由于不锁表,复制出来的数据是不一致的,在恢复的时候使用crash-recovery,使得数据恢复一致。

InnoDB维护了一个redo log,又称为transaction log(事务日志),它包含了InnoDB数据的所有改动情况。当InnoDB启动的时候,它会先去检查data file和transaction log,并且会做两步操作:

XtraBackup在备份的时候,一页一页的复制InnoDB的数据,而且不锁定表,与此同时,XtraBackup还有另外一个线程监视着transaction log,一旦log发生变化,就把变化过的log pages复制走。为什么要着急复制走呢?因为transaction log文件大小有限,写满之后,就会从头再开始写,所以新数据可能会覆盖到旧的数据。

在prepare过程中,XtraBackup使用复制到的transaction log对备份出来的InnoDB data file进行crash recovery。

3  XtraBackup备份特点

(1)备份过程快速、可靠

(2)备份过程不会打断正在执行的事务

(3)能够基于压缩等功能节约磁盘空间和流量

(4)自动实现备份检验

(5)还原速度快

4   XtraBackup安装

本来想用源码安装的,但总是不断报错,所以只好采用yum方法安装了

打开官网yum源安装方法说明

https://www.percona.com/doc/percona-xtrabackup/LATEST/installation/yum_repo.html

按照步骤安装官网的yum源

# yum install http://www.percona.com/downloads/percona-release/redhat/0.1-4/percona-release-0.1-4.noarch.rpm

# ls /etc/yum.repos.d/

CentOS-Base.repo       CentOS-fasttrack.repo  CentOS-Vault.repo  percona-release.repo

CentOS-Debuginfo.repo  CentOS-Media.repo      epel.repo

安装xtrabackup

# yum list|grep percona     #测试是否安装成功官网的yum源

# yum install percona-xtrabackup-24

# xtrabackup -version    #查看版本信息

也可以选用其他版本用rpm包方式安装

https://www.percona.com/downloads/XtraBackup/LATEST/binary/redhat/6/x86_64/

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

5  XtraBackup常用参数

--user=USER                     指定备份用户,不指定的话为当前系统用户

--password=PASSWD              指定备份用户密码

--port=PORT                     指定数据库端口

--defaults-group=GROUP-NAME     在多实例的时候使用

--host=HOST                     指定备份的主机,可以为远程数据库服务器

--apply-log    应用 BACKUP-DIR 中的 xtrabackup_logfile 事务日志文件。一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据文件仍处于不一致状态。“准备”的主要作用正是通过回滚未提交的事务及同步已经提交的事务至数据文件使得数据文件处于一致性状态。

--apply-log-only    这个选项使在准备备份(prepare)时,只执行重做(redo)阶段,这对于增量备份非常重要。

--database                     指定需要备份的数据库,多个数据库之间以空格分开

--defaults-file                 指定mysql的配置文件

--copy-back                     将备份数据复制回原始位置

--incremental                   增量备份,后面跟要增量备份的路径

--incremental-basedir=DIRECTORY 增量备份时使用指向上一次的增量备份所在的目录

--incremental-dir=DIRECTORY     增量备份还原的时候用来合并增量备份到全量,用来指定全备路径

--redo-only                     对增量备份进行合并

--rsync      加快本地文件传输,适用于non-InnoDB数据库引擎。不与--stream共用

--safe-slave-backup

--no-timestamp                  生成的备份文件不以时间戳为目录.

6    XtraBackup备份数据

6.1   全量备份

查看备份之前都有哪些库

mysql> show databases;

+--------------------+

| Database           |

+--------------------+

| information_schema |

| binlog             |

| database1          |

| mysql              |

| performance_schema |

| wangning           |

| wordpress          |

+--------------------+

7 rows in set (0.16 sec)

全备份数据存放在/data/backup/full下面,innobackupex会自动创建一个文件夹+以当前系统时间命名的文件夹

# innobackupex --defaults-file=/etc/my.cnf  --user=root --password=abc123 --socket=/tmp/mysql.sock /data/backup/full

# ls /data/backup/full/

2017-12-11_09-10-45

备份好的目录里各文件说明,×××部分为备份之前建的库

# ls /data/backup/full/2017-12-11_09-10-45/

backup-my.cnf  ibdata1             wangning                xtrabackup_checkpoints

binlog         mysql               wordpress               xtrabackup_info

database1      performance_schema  xtrabackup_binlog_info  xtrabackup_logfile

(1) backup-my.cnf —— 备份命令用到的配置选项信息;

(2) ibdata1 —— 备份的表空间文件;

(3) xtrabackup_binary —— 备份中用到的xtrabackup的可执行文件;

(4) xtrabackup_binlog_info —— mysql服务器当前正在使用的二进制日志文件及至备份这一刻为止二进制日志事件的位置;

(5) xtrabackup_logfile —— 备份的重做日志文件。

(6) xtrabackup_checkpoints —— 备份类型(如完全或增量)、备份状态(如是否已经为prepared状态)和LSN(日志序列号)范围信息;

# cat /data/backup/full/2017-12-11_09-10-45/xtrabackup_checkpoints

backup_type = full-backuped      #可以看出是全备份

from_lsn = 0                      #记录了LSN,日志偏移量

to_lsn = 8096126

last_lsn = 8096126

compact = 0

recover_binlog_info = 0

6.2   恢复全备数据

6.2.1  模拟数据库数据损坏

关闭数据库并移除数据文件

# service mysqld stop

# mv /application/mysql/data  /opt/

# mkdir /application/mysql/data    #创建数据目录

# chown -R mysql.mysql /application/mysql/data

6.2.2   准备完整的数据备份文件

一般情况下,这个/data/backup/full/2017-12-11_09-10-45备份不能用于恢复,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务,此时数据文件处于不一致的状态。因此,我们现在就是要通过回滚未提交的事务及同步已经提交的事务至数据文件也使得数据文件处于一致性状态。

# innobackupex --defaults-file=/etc/my.cnf  --user=root --password=abc123 --socket=/tmp/mysql.sock --apply-log /data/backup/full/2017-12-11_09-10-45/

6.2.3 开始恢复数据

# innobackupex --defaults-file=/etc/my.cnf --user=root --password=abc123 --socket=/tmp/mysql.sock  --copy-back /data/backup/full/2017-12-11_09-10-45

171211 10:03:07 innobackupex: Starting the copy-back operation

IMPORTANT: Please check that the copy-back run completes successfully.

At the end of a successful copy-back run innobackupex

prints "completed OK!".

innobackupex version 2.4.9 based on MySQL server 5.7.13 Linux (x86_64) (revision id: a467167cdd4)

Error: datadir must be specified.

当执行上述命令出现报错时,是因为my.cnf文件里没有指定datadir目录

解决方法:

[mysqld]

datadir = /application/mysql/data

启动mysql出现报错

# service mysqld start                                                    Starting MySQL. ERROR! The server quit without updating PID file (/application/mysql/data/db01.pid).

将data目录属主改为mysql即可

# chown -R mysql.mysql /application/mysql/data/

此时mysql的数据已成功恢复了

6.3 增量备份

增量备份是在全量备份的基础之上进行的

增量备份目录1:/data/backup/increment1

增量备份目录2:/data/backup/increment2

6.3.1    第一次增量备份和恢复

6.3.1.1  第一次增量备份

先全备再增备,全备见6.1

# innobackupex --defaults-file=/etc/my.cnf --user=root --password=abc123 --socket=/tmp/mysql.sock  --incremental /data/backup/increment1 --incremental-basedir=/data/backup/full/2017-12-11_09-10-45

生成一个以系统时间命名的文件夹

# ls /data/backup/increment1/

2017-12-11_10-51-27

--incremental-basedir指的是完全备份所在的目录,此命令执行结束后,innobackupex命令会在/data/backup/increment1目录中创建一个新的以时间命名的目录以存放所有的增量备份数据。另外,在执行过增量备份之后再一次进行增量备份时,其--incremental-basedir应该指向上一次的增量备份所在的目录。需要注意的是,增量备份仅能应用于InnoDB或XtraDB表,对于MyISAM表而言,执行增量备份时其实进行的是完全备份。

6.3.1.2  第一次增备恢复

准备完整的数据恢复文件

全备 --apply-log

# innobackupex --defaults-file=/etc/my.cnf  --user=root --password=abc123 --socket=/tmp/mysql.sock --apply-log  --redo-only /data/backup/full/2017-12-11_09-10-45/

增备1 --apply-log

# innobackupex --defaults-file=/etc/my.cnf  --user=root --password=abc123 --socket=/tmp/mysql.sock --apply-log  --redo-only /data/backup/full/2017-12-11_09-10-45/ --incremental-dir=/data/backup/increment1/2017-12-11_10-51-27

模拟数据库损坏,详见6.2.1

开始恢复数据,详见6.2.3

6.3.2  第二次增量备份和恢复

6.3.2.1  第二次增量备份

第二次增量备份是在第一次增量备份的基础上进行的

# innobackupex --defaults-file=/etc/my.cnf --user=root --password=abc123 --socket=/tmp/mysql.sock  --incremental /data/backup/increment2 --incremental-basedir=/data/backup/increment1/2017-12-11_10-51-27

生成一个以系统时间命名的文件夹

# ls /data/backup/increment2/

2017-12-11_10-58-55

6.3.2.2  第二次增备恢复

准备完整的数据恢复文件

增备2 --apply-log

# innobackupex --defaults-file=/etc/my.cnf  --user=root --password=abc123 --socket=/tmp/mysql.sock --apply-log  --redo-only /data/backup/full/2017-12-11_09-10-45/ --incremental-dir=/data/backup/increment2/2017-12-11_10-58-55

模拟数据库损坏,详见6.2.1

开始恢复数据,详见6.2.3

6.4    三次以上增量备份

按照6.3.2.2以此类推即可

转载于:https://blog.51cto.com/xiaocao13140/2121159

mysql物理备份工具Xtrabackup安装配置相关推荐

  1. mysql 物理备份工具_mysql物理备份工具Xtrabackup安装配置

    mysql物理备份工具Xtrabackup安装配置 1Xtrabackup工具介绍 Xtrabackup是一个对InnoDB做物理数据备份的工具,支持在线热备份(备份时不影响数据读写),是商业备份工具 ...

  2. MySQL · 物理备份 · Percona XtraBackup 备份原理

    前言 Percona XtraBackup(简称PXB)是 Percona 公司开发的一个用于 MySQL 数据库物理热备的备份工具,支持 MySQl(Oracle).Percona Server 和 ...

  3. Mysql第三方备份工具Xtrabackup使用说明

    1.Xtrabackup安装 1)yum安装方式: yuminstallhttp://www.percona.com/downloads/percona-release/redhat/0.1-3/pe ...

  4. Mysql备份工具xtrabackup 8 安装图解

    Mysql备份工具xtrabackup安装图解 声明 本文的数据来自网络,部分代码也有所参照,这里做了注释和延伸,旨在技术交流,如有冒犯之处请联系博主及时处理. 注: 当前操作系统CentOS 8.M ...

  5. mysql binlog2sql_mysql闪回工具binlog2sql安装配置教程详解

    概述 binlog2sql是一个Python开发开源的MySQL Binlog解析工具,能够将Binlog解析为原始的SQL,也支持将Binlog解析为回滚的SQL,去除主键的INSERT SQL,是 ...

  6. mysql 5.7 备份innodb_mysql5.7 innodb数据库备份工具Xtrabackup的安装

    mysql5.7 innodb数据库备份工具Xtrabackup的安装 wgetmhttps://www.percona.com/downloads/XtraBackup/Percona-XtraBa ...

  7. XtraBackup 物理备份工具

    原文地址:https://www.cpweb.top/1046 一.工具介绍   XtraBackup是percona公司的一个产品,它是用于MySQL的开源热备份工具,在备份过程中不会锁表(针对In ...

  8. MySQL备份Percona Xtrabackup安装和卸载

    MySQL备份Percona Xtrabackup安装和卸载 Percona XtraBackup 安装介绍篇 XtraBackup介绍 XtraBackup是Percona公司的开源项目,用以实现类 ...

  9. mysql企业备份工具(MEB)之mysqlbackup安装及使用

    mysql enterprise版比community在备份工具上有了提升,多了一个mysqlbackup的工具,即mysql企业备份工具. 当然遵循GPL的社区版也可以用: 该工具单独下载: 到官方 ...

最新文章

  1. MyBatis 一对多、多对一的处理~
  2. 浅析SEO优化中标签的作用?
  3. best tips for databases for graduate research
  4. MapReduce实例(数据去重)
  5. 卸载VMware Server后,无法加载登录用户界面 #F#
  6. with open as f用法_UE4精品教程 | C++Tuple元组的详细用法
  7. IntelliJ IDEA提示忽略大小写
  8. 最快的 java 图像_java – 最快的性能过滤图像
  9. mysql数据库表中重命名语句_mysql数据库重命名sql语句
  10. 随机森林算法原理解析
  11. HTML5绘制八大行星加入字体,html5中用canvas画八大行星围绕太阳转
  12. 计算机毕业设计之java+ssm疫情防控志愿者管理系统
  13. 「暑期训练」「基础DP」 Monkey and Banana (HDU-1069)
  14. 成都涌现大量网游业创业团队:从业人员近3万(网游亦可创业)
  15. 流畅chatbot采样
  16. bigemap地图源?
  17. AllWinner T113 DDR验证
  18. 2011级《软件设计模式》考试试题(开卷)
  19. Day437438439.秒杀服务 -谷粒商城
  20. [Unity 3D] 簡單瞭解「Collision碰撞」與「Trigger觸發」

热门文章

  1. centos 8 卸载anaconda_CentOS 7.8 (2003) 发布,附地址
  2. 转载:cin总结附带string输入总结
  3. PADS 9.5安装教程附安装包资源
  4. JavaWeb(六)——HttpServletResponse、HttpServletRequest
  5. css实现快速抖动效果_web前端入门到实战:CSS实现照片堆叠效果
  6. C++ | C++实现高精度加法——数组加法(附源代码)
  7. Android studio | From Zero To One ——初级控件(屏幕显示)
  8. VHDL | 音乐盒设计(代码类)
  9. 搭量化数据库——互联网金融之三
  10. hbuilder怎么设置网页的大小_大明:网页字体大小怎么调?教你方法一键搞定