xtrabackup 2.4 的介绍与使用
抄袭转载的太多,请认准原文链接: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
注意事项
常用概念和参数
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 的介绍与使用的更多相关文章
- MySQL 使用XtraBackup的shell脚本介绍
mysql_backup.sh是关于MySQL的一个使用XtraBackup做备份的shell脚本,实现了简单的完整备份和增量备份.以及邮件发送备份信息等功能.功能目前还比较简单,后续将继续完善和增加 ...
- 使用xtrabackup备份mysql数据库
数据在一个企业里非常重要,因此经常需要备份数据库,确保出线故障时,可以立刻恢复数据到最新状态,目前常见的备份工具有mysqldump和xtrabackup,数据量较少时可以使用mysqldump,但随 ...
- Percona Xtrabackup备份mysql(转)
add by zhj:另外,参考了Xtrabackup之innobackupex备份恢复详解,我用的是Xtrabackup2.2.6版本, 可以成功备份和恢复指定的数据库. 原文:http://www ...
- Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)
原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...
- 【mysql】使用xtrabackup在线增量备份及恢复数据库
一.Percona Xtrabackup 简介 1.Xtrabackup bin目录文件 介绍 1)innobackupex innobackupex 是xtrabackup的一个符号链接 . in ...
- (4.15)mysql备份还原——物理备份之XtraBackup的下载与安装
关键词:mysql物理备份,XtraBackup,XtraBackup安装,XtraBackup下载 实践链接:https://www.cnblogs.com/gered/p/11147193.htm ...
- Percona Xtrabackup备份mysql大数据库(完整备份与增量备份)
Percona Xtrabackup备份mysql大数据库(完整备份与增量备份) 文章目录 [隐藏] Xtrabackup简介 Xtrabackup安装 Xtrabackup工具介绍 inno ...
- MySQL 博客文章目录(2016-08-20更新)
1 MySQL安装配置 Linux MySQL源码安装缺少ncurses-devel包 Linux平台卸载MySQL总结 Linux 卸载mysql-libs包出现错误 2 MySQL管理配置 My ...
- 第七章 mysql 事务索引以及触发器,视图等等,很重要又难一点点的部分
[索引] 帮助快速查询 MyISAM ,InnoDB支持btree索引 Memory 支持 btree和hash索引 存储引擎支持 每个表至少16个索引 总索引长度至少256字节 创建索引的优 ...
- MySQL 博客文章目录(2017-02-18更新)
1MySQL安装配置 Linux MySQL源码安装缺少ncurses-devel包 Linux平台卸载MySQL总结 Linux 卸载mysql-libs包出现错误 CentOS 7 安装MySQL ...
随机推荐
- PB从入坑到放弃(四)常用函数
写在前面 这一期呢,来整理下PB 常用的函数,包括系统的和一些自己封装好的函数 一.字符串相关 1.1 Len函数 获取字符串长度 ① 语法 Len(string) ②参数 string-->s ...
- nuitka 将程序编译为单个exe
原文链接:https://github.com/Nuitka/Nuitka 在Windows上,有两种模式,一种是将其复制到您公司指定的AppData,也将其用作缓存,另一种是在临时目录中进行.您需要 ...
- C#的重载决策
重载是许多编程语言支持的特性.所谓重载,就是指可以定义多个名称相同但参数(个数.类型和顺序)不同的方法(函数).先来看一个例子: void Main() { char cvalue = 'a'; ma ...
- lazarus、delphi文件Http下载断点续传的实现
下载大文件时,断点续传是很有必要的,特别是网速度慢且不稳定的情况下,很难保证不出意外,一旦意外中断,又要从头下载,会很让人抓狂.断点续传就能很好解决意外中断情况,再次下载时不需要从头下载,从上次中断处 ...
- AI绘画关键词Prompt:分享一些质量比较高的StableDiffusion(SD)关键词网站
今天向大家推荐一些SD(StableDiffusion)高质量的 关键词 网站.这些网站的质量可靠,能为大家在创建 AI 绘画时提供有效的参考.以下是六个推荐的网站,优缺点分析. 有几个质量还算是挺高 ...
- 从原理聊 JVM(五):JVM 的编译过程和优化手段
一.前端编译 前端编译就是将Java源码文件编译成Class文件的过程,编译过程分为4步: 1 准备 初始化插入式注解处理器(Annotation Processing Tool). 2 解析与填充符 ...
- WPF学习 - 用鼠标移动、缩放、旋转图片(1)
1. 需求 其实我的需求很简单.就是想做一个图片查看器,可以通过鼠标来平移.缩放.旋转图片. 2. 解决思路: WPF中的UIElement提供了RenderTransform属性,用于承载各种Tra ...
- TOML格式简介
TOML(Tom's Obvious, Minimal Language)是一种用于配置文件的轻量级文本格式,旨在易于阅读和编写.它的设计目标是简单明了,同时也能表达复杂的数据结构.TOML文件通常用 ...
- 探索计算机的I/O控制方式:了解DMA控制器的作用与优势
I/O控制方式 在前面我们已经了解到,每个设备都配备了一个设备控制器.当CPU向设备控制器发送命令并将其存储在寄存器中时,设备控制器会执行相应的操作.然而,尽管设备控制器会更新状态寄存器的状态,但是如 ...
- 【译】在 Visual Studio 2022 中安全地在 HTTP 请求中使用机密
在 Visual Studio 2022 的17.8 Preview 1版本中,我们更新了 HTTP 文件编辑器,使您能够外部化变量,从而使跨不同环境的 Web API 测试更容易.此更新还包括以安全 ...