iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >mysql物理备份工具Xtrabackup安装配置
  • 801
分享到

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

2024-04-02 19:04:59 801人浏览 八月长安
摘要

mysql物理备份工具Xtrabackup安装配置1    Xtrabackup工具介绍Xtrabackup是一个对InnoDB做物理数据备份的工具,支持在线热备份(

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/

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以此类推即可


您可能感兴趣的文档:

--结束END--

本文标题: mysql物理备份工具Xtrabackup安装配置

本文链接: https://www.lsjlt.com/news/36556.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • mysql-物理备份-Percona xtrabackup
    xtrabackup是percona公司开发的一个用于mysql物理热备的备份工具。 软件安装后一共有4个可执行文件:      innobackupex:pe...
    99+
    2024-04-02
  • MySQL xtrabackup 物理备份原理解析
    目录一、简介二、xtrabackup备份原理:三、xtrabackup备份流程四、xtrabackup常用命令选项:五、xtrabackup备份实践六、xtrabackup备份日志分析七、xtrabackup备份的gen...
    99+
    2022-12-21
    MySQLxtrabackup物理备份原理 MySQLxtrabackup 备份原理
  • mysql之 percona-xtrabackup 2.4.7安装(热备工具)
    准备:os是centos6.7,提前下载并上传 percona-xtrabackup 安装包,下载网址为: https://www.percona.com/downloads/XtraBackup/LATE...
    99+
    2024-04-02
  • mysql物理备份利器xtrabackup怎么用
    今天就跟大家聊聊有关mysql物理备份利器xtrabackup怎么用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。安装cd /opt/tar -zx...
    99+
    2024-04-02
  • CentOS7.x 安装mysql5.7 XtraBackUp备份工具使用命令详解
    目录mysql安装1.mysql下载2.安装mysql3.配置mysql4.数据库备份4.1备份的种类4.2备份时数据库的状态4.3备份文件的格式4.4备份内容4.5备份工具4.6O...
    99+
    2024-04-02
  • aws s3桶备份工具 s3cmd安装配
    在防止个人和工作文件丢失或受损方面,已安装的数据备份系统是远远不够的。理想情况下,数据应该安全可靠地存储一个或多个远离您家或办公室的地方。所以,即使已经在优盘里备份了(过时的)文档,并在Google Drive同步备份了一部分,再增加一种备...
    99+
    2023-01-31
    备份工具 aws s3cmd
  • 如何配置xtrabackup备份mysql数据库
    这篇文章将为大家详细讲解有关如何配置xtrabackup备份mysql数据库,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。1    安装yum源:yu...
    99+
    2024-04-02
  • PostgreSQL物理备份工具pg_rman目怎么用
    这篇文章给大家分享的是有关PostgreSQL物理备份工具pg_rman目怎么用的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。OS: Ubuntu 16.04.4 LTSdata...
    99+
    2024-04-02
  • mysql企业备份工具mysqlbackup如何安装使用
    这篇文章主要介绍mysql企业备份工具mysqlbackup如何安装使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! mysql enterprise版...
    99+
    2024-04-02
  • Linux 进程管理工具之Supervisor安装配置
    目录前言安装生成配置配置文件参数说明配置管理进程启动服务控制进程交互终端bash终端开机启动服务前言 Supervisor 是用 Python 开发的一个 client/server...
    99+
    2023-05-19
    Linux 进程管理Supervisor Linux 进程管理
  • Linux 进程管理工具之Supervisor安装配置
    目录前言安装生成配置配置文件参数说明配置管理进程启动服务控制进程交互终端bash终端开机启动服务前言 Supervisor 是用 python 开发的一个 client/server 服务,是linux/Unix系统下的...
    99+
    2023-05-12
    Linux 进程管理Supervisor Linux 进程管理
  • NBU 8.0客户端安装和备份配置
    suse 11sp4 nbu client 8.0 首先将客户端地址和服务端地址添加到相互hosts文件中。 nbu 8.0支持Oracle 12c备份,备份脚本包括各种模板 FA1XXXXXXS00...
    99+
    2024-04-02
  • 怎么安装和配置Apache Pig工具
    安装和配置Apache Pig工具的步骤如下: 下载并安装Apache Pig:首先需要从Apache Pig官方网站(http...
    99+
    2024-04-02
  • Win7/Win8.1全新安装Win10工具 密钥一键查询备份
    2016年7月29日,微软关闭Win7/Win8.1免费升级Win10的通道,本文发稿时间为关闭前一天,此时如果还有用户想升级Windows10但没有升级的,可以尝试使用本文方法进行全新安装。全新安装的好处就是不会产生新...
    99+
    2023-05-21
    Win10 Win7
  • macOS安装和配置mysql具体步骤
            MySQL是一个开源的关系数据库管理系统(RDBMS),广泛用于构建Web应用程序和管理大型数据集。它使用SQL(结构化查询语言)作为管理数据的主要语言,它因其易用性、可靠性和可扩展性而广受欢迎。MySQL是由Oracle公...
    99+
    2023-08-31
    mysql 数据库
  • 在Linux上怎么安装和配置DenyHosts工具
    本篇内容主要讲解“在Linux上怎么安装和配置DenyHosts工具”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“在Linux上怎么安装和配置DenyHosts工具”吧!  使用DenyHost...
    99+
    2023-06-12
  • Linux系统如何安装及配置ClusterShell工具
    这篇文章主要介绍“Linux系统如何安装及配置ClusterShell工具”,在日常操作中,相信很多人在Linux系统如何安装及配置ClusterShell工具问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”L...
    99+
    2023-06-13
  • FileZilla-Linux ftp上传工具如何安装配置
    这篇文章主要为大家展示了“FileZilla-Linux ftp上传工具如何安装配置”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“FileZilla-Linux ftp上传工具如何安装配置”这篇...
    99+
    2023-06-16
  • 怎么在windows下安装配置python工具Ulipad
    要在Windows下安装和配置Ulilpad,您可以按照以下步骤操作: 下载Python安装程序:首先,您需要在您的计算机上安装...
    99+
    2024-03-02
    Python Ulipad
  • redis数据备份和迁移工具redis-dump如何安装使用
    这篇文章主要介绍redis数据备份和迁移工具redis-dump如何安装使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一.安装:# git clone https://githu...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作