抄袭转载的太多,请认准原文链接:xtrabackup的介绍与使用

前言

在网上找到教程都是复制粘贴抄袭的,而且还是陈旧资料,不得不说,当前中文互联网环境真是每况愈下。

如果你在网上找 xtrabackup 的教程,大概率会为你介绍 innobackupex。但在最新的 2.4 版本中,innobackupex 已经废弃,只是一个指向 xtrabackup 的软连接,官方推荐使用 xtrabackup,原文地址:The innobackupex Program

本文教程使用的是 xtrabackup 2.4.28,是当前(本文发布时)最新的 xtrabackup2.4 版本,可以备份 MySQL 5.1、5.5、5.6 和 5.7 服务器上的 InnoDB、XtraDB 和 MyISAM 表的数据,以及带有 XtraDB 的 Percona Server。

环境安装

教程中使用 MySQL 5.7 版本,其安装方式不多赘述,主要介绍 xtrabackup 的安装,如果你已经准备好了环境可以略过此步,这里介绍三种不同的方式。

Docker

个人推荐使用 docker 安装的方式,这里贴出完整的 docker-compose.yml,仅供参考:

version: "3.7"
services:
xtrabackup:
image: percona/percona-xtrabackup:2.4.28
container_name: xtrabackup
restart: "always"
command: bash -c "while true; do sleep 1; done"
volumes:
- "/home/docker/xtrabackup:/data"
# 这里需要把 MySQL 的数据目录映射到容器中,原因请查看下文的注意事项
- "/home/docker/mysql/data/:/var/lib/mysql"

command 命令是一个简单的 while 循环,用来保持容器运行,方便进入其中执行命令。

Debian/Ubuntu

从 Percona web 下载 deb 包

wget https://repo.percona.com/apt/percona-release_latest.$(lsb_release -sc)_all.deb

安装 dpkg,这一步需要 root 权限

sudo dpkg -i percona-release_latest.$(lsb_release -sc)_all.deb

启用存储库

percona-release enable-only tools release

apt 安装 xtrabackup

sudo apt install percona-xtrabackup-24

apt 安装 qpress, qpress 用于压缩备份

sudo apt install qpress

Red Hat/CentOs

安装 percona-release:

yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpm

RHEL | Centos5 不支持直接从远程位置安装软件包,因此您需要先下载软件包并使用 rpm 手动安装:

wget https://repo.percona.com/yum/percona-release-latest.noarch.rpm
rpm -ivH percona-release-latest.noarch.rpm

启用存储库:

percona-release enable-only tools release

yum 安装 xtrabackup:

yum install percona-xtrabackup-24

yum 安装 qpress, qpress 用于压缩备份:

yum install qpress

注意事项

xtrabackup 在备份时需要访问 MySQL 的数据目录,且具备操作它的权限,所以 MySQL 和 xtrabackup 不在同一主机的情况下,需要把 MySQL 的数据拷贝到 xtrabakcup 所在的主机上。

常用概念和参数

xtrabakcup 有几个常见的概念:

  • 完整备份:顾名思义,就是完整备份 o.O
  • 恢复备份:顾名思义,就是恢复备份 O.o
  • 准备备份:这个不能顾名思义了,它用来把完整备份出来的数据文件进行一些处理,处理后的数据才能用于恢复备份
  • 增量备份:每一次完整备份的数据文件会很大,增量备份会在其基础上做备份,这样可以节省资源
  • 压缩备份:把备份文件进行压缩,以节省空间

这里是几个常用xtrabackup 命令参数,在后续不明白时,可以过来查询

  • --backup 制作一个备份并放在 --target-dir 中,这个是制作完整备份和增量备份的必要参数
  • --prepare 创建准备备份
  • --target-dir 指定备份文件的目录,不存在将自动创建
  • --apply-log-only 这个选项在准备备份时使用,让其只执行 redo 阶段,一般用在增量备份上
  • --host 指定 MySQL 的 host
  • --port 指定 MySQL 的 port
  • --password 指定 MySQL 的密码
  • --defaults-file 指定 my.cnf,不能是 my.cnf 的软链接
  • --datadir 指定 MySQL 的数据目录,一般会从 my.cnf 中读取

预备数据

我们先预备一下 MySQL 的测试数据,创建一个用于测试的数据库:

CREATE DATABASE test;

创建一个表,并填充数据:

CREATE TABLE `user`  (
`id` int(10) UNSIGNED NOT NULL AUTO_INCREMENT,
`name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci NULL DEFAULT NULL,
PRIMARY KEY (`id`) USING BTREE
) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8mb4 COLLATE = utf8mb4_general_ci ROW_FORMAT = Dynamic; INSERT INTO `user` (name) VALUES ("oldme");
INSERT INTO `user` (name) VALUES ("newton");
INSERT INTO `user` (name) VALUES ("watt");

完整备份

创建备份

xtrabackup --backup --host=mysql --password=12345678 --target-dir=/data/backups/base/

完成后的效果:

查看备份出来的文件:ls -l /data/backups/base

然后我们删掉一条数据,以做恢复数据展示:

DELETE FROM `user` WHERE id=3

准备备份

必须先要准备备份后才能恢复数据:

xtrabackup --prepare --target-dir=/data/backups/base/

完成后的效果:

恢复备份

在恢复备份前需要关闭 MySQL 服务。

// base后面一定要带/
rsync -avrP /data/backups/base/ /var/lib/mysql/

恢复数据后更改文件所有权,如果是 docker 部署则略过:

chown -R mysql:mysql /var/lib/mysql

重启 MySQL 服务,查看恢复完成的数据:

SELECT* FROM `user`

id	name
--------------
1 oldme
2 newton
3 watt

增量备份

创建备份

在创建增量备份前,我们需要有一个完整备份:

xtrabackup --backup --host=mysql --password=12345678 --target-dir=/data/backups/base/

给数据库新增一条数据:

INSERT INTO `user` (name) VALUES ("Einstein");

然后以此为基础进行增量:

xtrabackup --backup --host=mysql --password=12345678 --target-dir=/data/backups/inc1 --incremental-basedir=/data/backups/base

/data/backups/inc1/ 目录现在应该包含增量文件,例如 ibdata1.delta 和 test/user.ibd.delta。

还可以以 inc1 为基础继续增量:

xtrabackup --backup --host=mysql --password=12345678 --target-dir=/data/backups/inc2 --incremental-basedir=/data/backups/inc1

删除数据,准备恢复:

DELETE FROM `user` WHERE id in (3,4)

准备备份与恢复

准备备份与完整备份不同,需要使用 --apply-log-only 选项来保持数据库一致。

先准备基础备份:

xtrabackup --prepare --apply-log-only --target-dir=/data/backups/base/

将增量备份应用到基础备份中:

xtrabackup --prepare --apply-log-only --target-dir=/data/backups/base --incremental-dir=/data/backups/inc1

然后执行同样的恢复备份命令,这点与完整备份的步骤一样,停止 MySQL 服务,执行命令,重启 MySQL:

// base后面一定要带/
rsync -avrP /data/backups/base/ /var/lib/mysql/

最后即可看到恢复的数据:

id	name
--------------
1 oldme
2 newton
3 watt
4 Einstein

压缩备份

创建压缩备份

xtrabackup --backup --compress --host=mysql --password=12345678 --target-dir=/data/backups/compressed/

可以使用 --compress-threads 配置多线程压缩,例如启用四个线程压缩:

xtrabackup --backup --compress --host=mysql --password=12345678 --compress-threads=4 --target-dir=/data/backups/compressed/

准备备份

在准备备份之前需要解压备份:

xtrabackup --decompress --target-dir=/data/backups/compressed/

解压完成后使用和完整备份一样的方式就可以恢复备份数据了。

xtrabackup 2.4 的介绍与使用的更多相关文章

  1. MySQL 使用XtraBackup的shell脚本介绍

    mysql_backup.sh是关于MySQL的一个使用XtraBackup做备份的shell脚本,实现了简单的完整备份和增量备份.以及邮件发送备份信息等功能.功能目前还比较简单,后续将继续完善和增加 ...

  2. 使用xtrabackup备份mysql数据库

    数据在一个企业里非常重要,因此经常需要备份数据库,确保出线故障时,可以立刻恢复数据到最新状态,目前常见的备份工具有mysqldump和xtrabackup,数据量较少时可以使用mysqldump,但随 ...

  3. Percona Xtrabackup备份mysql(转)

    add by zhj:另外,参考了Xtrabackup之innobackupex备份恢复详解,我用的是Xtrabackup2.2.6版本, 可以成功备份和恢复指定的数据库. 原文:http://www ...

  4. Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)

    原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...

  5. 【mysql】使用xtrabackup在线增量备份及恢复数据库

    一.Percona Xtrabackup 简介 1.Xtrabackup  bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...

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

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

  7. Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)

    Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)     文章目录 [隐藏] Xtrabackup简介 Xtrabackup安装 Xtrabackup工具介绍 inno ...

  8. MySQL 博客文章目录(2016-08-20更新)

    1 MySQL安装配置 Linux MySQL源码安装缺少ncurses-devel包 Linux平台卸载MySQL总结 Linux 卸载mysql-libs包出现错误 2  MySQL管理配置 My ...

  9. 第七章 mysql 事务索引以及触发器,视图等等,很重要又难一点点的部分

    [索引] 帮助快速查询 MyISAM ,InnoDB支持btree索引 Memory 支持 btree和hash索引 存储引擎支持 每个表至少16个索引   总索引长度至少256字节   创建索引的优 ...

  10. MySQL 博客文章目录(2017-02-18更新)

    1MySQL安装配置 Linux MySQL源码安装缺少ncurses-devel包 Linux平台卸载MySQL总结 Linux 卸载mysql-libs包出现错误 CentOS 7 安装MySQL ...

随机推荐

  1. List去除重复数据的五种方式

    来自:CSDN,作者:多纤果冻 链接:https://blog.csdn.net/qq_37939251/article/details/90713643 以下介绍五种-不同的方法去除 Java 中A ...

  2. NSSCTF-[羊城杯 2021]签到题

    (脑洞题 gif放在stegsolve,分离gif 大胆猜测! 图一 28准则 图二 太极八卦阵 8 图三 三十而立 30 图四 北斗七星 7 图五 四个人 4大才子 图六 这个是歼-20 图七 两只 ...

  3. js实现图片预览翻页

    原文地址 可以直接复制粘贴打开,图片是在线的,原理简单好懂! 效果 源码 <!DOCTYPE html> <html> <!--JQuery在线引用--> < ...

  4. 运维自动化工具--Ansible

    运维自动化工具Ansible 1. ansible安装 rocky安装 需要先安装 enel源 # yum install -y epel-release 然后再安装ansible # yum ins ...

  5. std::ofstream 写本地音频

    最近线上 PK 偶然出现双方主播互相听不见声音的情况,在日志不能明确体现问题时,就需要抓下主播本地的音频和远端的音频来确定数据是在哪消失的 所以我们用到一个比较简单的流写出的标准库类:std::ofs ...

  6. Unity UGUI的LayoutElement(布局元素)组件的介绍及使用

    Unity UGUI的LayoutElement(布局元素)组件的介绍及使用 1. 什么是LayoutElement组件? LayoutElement是Unity UGUI中的一个布局元素组件,用于控 ...

  7. Linux 上 KVM 虚拟机网络问题

    通过控制台连接虚拟机,ping自己的ip,ping宿主机的ip,ping同网段的ip 1. 自己的ip也不通,先检查网络配置 2. 宿主机的ip不通,就要确认下虚拟机网卡的类型 对于macvlan网卡 ...

  8. 理解TCP3次握手

    以AB通话为例 A的视角 A给B打电话,进入SYN_SENT B接起电话,A确认后,进入ESTABLISHED B的视角 看到A打过来的电话,接起电话,进入SYN_RCVD 确认对方后,进入ESTAB ...

  9. 王道oj/problem15(用c++的引用精简代码)

    网址:http://oj.lgwenda.com/problem/15 思路:子函数的形参是指针的时候格式为 int*&p,且原函数实参为p 主函数使用fgets(字符串的指针,最大容量,st ...

  10. Blazor前后端框架Known-V1.2.11

    V1.2.11 Known是基于C#和Blazor开发的前后端分离快速开发框架,开箱即用,跨平台,一处代码,多处运行. Gitee: https://gitee.com/known/Known Git ...