MySQL物理备份
目录
备份策略
全量备份 (Full Backup)
增量备份 (Incremental Backup)
差异备份 (Differential Backup)
使用 Percona XtraBackup
全量备份
步骤 1:全量备份
步骤 2:备份后处理(应用日志)
步骤 3:恢复备份
验证备份
增量备份
概述步骤
示例步骤
假设备份目录结构
步骤 1:全量备份
步骤 2:第一次增量备份
步骤 3:第二次增量备份
步骤 4:预处理全量备份
步骤 5:应用第一次增量备份
步骤 6:应用第二次增量备份
步骤 7:最终预处理
步骤 8:清理原数据目录
步骤 9:恢复备份到数据目录
步骤 10:调整权限
步骤 11:启动 MySQL 服务
差异备份
概述步骤
示例步骤
假设备份目录结构
步骤 1:全量备份
步骤 2:第一次差异备份
步骤 3:第二次差异备份
步骤 4:预处理全量备份
步骤 5:应用第一次差异备份
步骤 6:应用第二次差异备份
步骤 7:最终预处理
步骤 8:恢复备份到数据目录
扩展:
InnoDB Hot Backup (InnoDB 冷备份)
功能比较
1. XtraBackup
2. innobackupex
迁移与升级
MySQL的物理备份涉及直接复制数据库的物理文件,如数据文件、二进制日志文件等。这种备份方式通常更快捷,特别适用于大型数据库。
备份策略
全量备份 (Full Backup)
定义:
全量备份是对指定的数据集进行完整的备份。这意味着所有数据在备份点上都被复制,因此可以完全恢复备份时刻的整个数据库。
特点:
- 每次备份都包含所有数据。
- 备份文件大,备份及恢复时间相对较长。
- 容易管理,因为每个备份均可独立恢复。
适用场景:
- 小型数据库,数据量不大且可以在可接受的时间内完成备份。
- 维护简单的备份方案。
增量备份 (Incremental Backup)
定义:
增量备份是指在上次备份(无论是全量备份还是增量备份)后对变化的数据进行备份。这些变化的数据包括增加或修改的数据。
特点:
- 备份文件最小。
- 备份速度最快,但恢复过程最复杂,需要依次应用全量备份和所有后续的增量备份。
- 适用于数据变化频繁且备份窗口很短的情况。
适用场景:
- 大型数据库,需要最小化的备份时间和存储空间。
- 高频率的数据变动,数据需要频繁地备份。
差异备份 (Differential Backup)
定义:
差异备份是指在上次全量备份后,对变化的数据进行备份。这些变化的数据包括随着时间的推移被创建或修改的数据。
特点:
- 比全量备份小,但随着时间增加会变得越来越大。
- 备份速度较快,但恢复时需要使用最近的全量备份与最新的差异备份。
- 备份文件相对较少,便于管理。
适用场景:
- 中型数据库,需要更快的备份速度但可以接受适度复杂的恢复过程。
- 数据变动较为频繁,每天做全量备份无法完成。
使用 Percona XtraBackup
Percona XtraBackup
是一种免费、开源的物理备份工具,适用于MySQL和Percona Server数据库,支持热备份。
官网:Percona XtraBackup for MySQL - Top MySQL Backup Solution
安装
yum -y install https://repo.percona.com/yum/percona-release-latest.noarch.rpm
percona-release enable-only tools release
yum -y install percona-xtrabackup-80
全量备份
步骤 1:全量备份
确保 MySQL 服务正在运行:
确保 MySQL 服务正在运行,这样可以进行热备份(无需停止数据库)。
systemctl status mysqld
执行全量备份:
使用 xtrabackup --backup
命令来创建全量备份,并指定目标目录。
xtrabackup --backup --target-dir=/path/to/backup_dir
例如下述:
假设备份目录为 /backups/full_backup
:(该目录需提前创建)
xtrabackup --backup --target-dir=/backups/full_backup
步骤 2:备份后处理(应用日志)
在进行备份时,InnoDB表的数据文件中尚有未完成的事务。要在恢复时确保数据的一致性,需要执行 --prepare
步骤。这将应用备份期间收集的所有日志文件。--prepare
或 --apply-log是一样的,
用来执行相同的操作,它会应用 REDO 和 UNDO 日志,使得备份数据变得一致。
准备备份:
使用 --prepare
选项应用日志。
xtrabackup --prepare --target-dir=/path/to/backup_dir
对于刚才的例子:
xtrabackup --prepare --target-dir=/backups/full_backup
完成这个步骤后,备份目录就准备好进行恢复了。
步骤 3:恢复备份
停 止 MySQL 服务:
需要停止当前正在运行的 MySQL 服务以进行数据恢复。
systemctl stop mysqld
恢复数据目录:
先去清理数据目录
rm -rf /var/lib/mysql/*
然后将备份内容复制到 MySQL 数据目录。目录位置在/var/lib/mysql
,也可以检查你的 MySQL 配置文件(my.cnf)确认数据目录位置。
xtrabackup --copy-back --target-dir=/path/to/backup_dir
对于上方的例子:
xtrabackup --copy-back --target-dir=/backups/full_backup
检查权限:
确保数据目录的所有文件都由 MySQL 用户拥有。
chown -R mysql:mysql /var/lib/mysql
启动 MySQL 服务:
启动 MySQL 服务以确保还原的备份正常运行。
systemctl start mysqld
验证备份
登录 MySQL:
确保 MySQL 服务已恢复并正常运行。
mysql -u root -p[密码]
验证数据:
检查数据库是否已经成功恢复,运行一些查询来验证数据的完整性。
增量备份
概述步骤
- 全量备份:创建一个基础备份,包含当前数据库的所有数据。
- 第一次增量备份:基于全量备份创建增量备份,包含自全量备份以来的所有更改。
- 第二次增量备份:基于第一次增量备份创建增量备份,包含自第一次增量备份以来的所有更改。
- 预处理全量备份:将全量备份应用日志,准备合并增量备份。
- 应用第一次增量备份:合并第一次增量备份到全量备份中。
- 应用第二次增量备份:合并第二次增量备份到全量备份中。
- 最终预处理:确保所有更改应用,使得备份达到一致状态。
- 恢复备份到 MySQL 数据目录。
示例步骤
假设备份目录结构
- 全量备份目录:
/backups/full_backup
- 第一次增量备份目录:
/backups/incremental_backup1
- 第二次增量备份目录:
/backups/incremental_backup2
步骤 1:全量备份
执行全量备份:
xtrabackup --backup --target-dir=/backups/full_backup
步骤 2:第一次增量备份
基于全量备份进行第一次增量备份:
xtrabackup --backup --target-dir=/backups/incremental_backup1 --incremental-basedir=/backups/full_backup
步骤 3:第二次增量备份
基于第一次增量备份进行第二次增量备份:
xtrabackup --backup --target-dir=/backups/incremental_backup2 --incremental-basedir=/backups/full_backup
步骤 4:预处理全量备份
首次预处理全量备份,应用第一次 REDO 日志:
xtrabackup --prepare --target-dir=/backups/full_backup
步骤 5:应用第一次增量备份
将第一次增量备份合并到全量备份中,并且此时只应用 REDO 日志:
xtrabackup --prepare --apply-log --redo-only --target-dir=/backups/full_backup --incremental-dir=/backups/incremental_backup1
步骤 6:应用第二次增量备份
将第二次增量备份合并到全量备份中,同样只应用 REDO 日志:
xtrabackup --prepare --apply-log --redo-only --target-dir=/backups/full_backup --incremental-dir=/backups/incremental_backup2
步骤 7:最终预处理
进行最终预处理,应用所有 REDO 和 UNDO 日志,确保数据达到一致状态:
xtrabackup --prepare --target-dir=/backups/full_backup
步骤 8:清理原数据目录
在恢复之前,清理 MySQL 数据目录:
systemctl stop mysqld
rm -rf /var/lib/mysql/*
步骤 9:恢复备份到数据目录
恢复备份数据到 MySQL 数据目录:
xtrabackup --copy-back --target-dir=/backups/full_backup
步骤 10:调整权限
确保 MySQL 数据目录权限正确:
sudo chown -R mysql:mysql /var/lib/mysql
步骤 11:启动 MySQL 服务
重新启动 MySQL 服务:
systemctl start mysqld
差异备份
差异备份(Differential Backup)是指在某个基准点(通常是全量备份)之后,只备份自基准点以来发生了变化的所有数据。与增量备份不同的是,差异备份总是基于同一个基准点,而增量备份则是基于上一个备份。
概述步骤
- 进行全量备份:创建初始的全量备份,作为基准点。
- 进行第一次差异备份:自全量备份以来的所有变化。
- 进行第二次差异备份:自全量备份以来的所有变化。
- 预处理全量备份:准备和合并差异备份。
- 应用第一次差异备份:将第一次差异备份合并到全量备份。
- 应用第二次差异备份:将第二次差异备份合并到全量备份。
- 最终预处理:确保所有更改应用,使得备份达到一致状态。
- 恢复备份到 MySQL 数据目录。
示例步骤
假设备份目录结构
- 全量备份目录:
/backups/full_backup
- 第一次差异备份目录:
/backups/differential_backup1
- 第二次差异备份目录:
/backups/differential_backup2
步骤 1:全量备份
执行全量备份:
xtrabackup --backup --target-dir=/backups/full_backup
步骤 2:第一次差异备份
进行第一次差异备份,基于全量备份:
xtrabackup --backup --target-dir=/backups/differential_backup1 --incremental-basedir=/backups/full_backup
步骤 3:第二次差异备份
进行第二次差异备份,仍然基于全量备份:
xtrabackup --backup --target-dir=/backups/differential_backup2 --incremental-basedir=/backups/full_backup
步骤 4:预处理全量备份
首次预处理全量备份,准备合并差异备份:
xtrabackup --prepare --target-dir=/backups/full_backup
步骤 5:应用第一次差异备份
将第一次差异备份合并到全量备份中,并且此时只应用 REDO 日志:
xtrabackup --prepare --apply-log --redo-only --target-dir=/backups/full_backup --incremental-dir=/backups/differential_backup1
步骤 6:应用第二次差异备份
将第二次差异备份合并到全量备份中,仍然只应用 REDO 日志:
xtrabackup --prepare --apply-log --redo-only --target-dir=/backups/full_backup --incremental-dir=/backups/differential_backup2
步骤 7:最终预处理
进行最终预处理,应用所有 REDO 和 UNDO 日志,确保数据达到一致状态:
xtrabackup --prepare --target-dir=/backups/full_backup
步骤 8:恢复备份到数据目录
清理 MySQL 数据目录,然后恢复备份数据:
systemctl stop mysqld
rm -rf /var/lib/mysql/*xtrabackup --copy-back --target-dir=/backups/full_backupchown -R mysql:mysql /var/lib/mysql
systemctl start mysqld
扩展:
XtraBackup 和 innobackupex 都是用于 MySQL 和 MariaDB 数据库的一致性备份工具。它们都由 Percona 提供,并常用于对 InnoDB 存储引擎进行热备份(即在数据库运行时进行备份)。不过,它们之间还是有一些显著的区别。
InnoDB Hot Backup (InnoDB 冷备份)
-
XtraBackup:
- 是一个专门用于对 InnoDB 存储引擎进行热备份的命令行工具。它比较简洁,功能专一,但对于复杂的备份操作可能需要更多的手动配置或者结合其他工具使用。
-
innobackupex:
- 是 Percona XtraBackup 中的一个 Perl 脚本,它实际上是一个高级封装,使用 XtraBackup 来实现具体的备份和恢复操作。innobackupex 增加了一些便利功能,例如备份 MyISAM 表,但因为 MyISAM 表备份期间需要静态锁定,所以不算是真正的“热备份”。
功能比较
1. XtraBackup
- 优势:
- 简单直接:直接进行 InnoDB 存储引擎的数据备份。
- 更高效:更少的额外依赖,直接进入备份行为。
- 控制精确:对于高级用户可以提供更多的控制选项。
- 限制:
- 需要更多配置:可能需要更多的手动步骤来完成备份计划。
- 通用性较低:不像 innobackupex 那样能够同时处理多种存储引擎。
2. innobackupex
-
优势:
- 易用性高:封装了更多功能,用户友好性更高。
- 处理多种存储引擎:可以同时备份 InnoDB 和 MyISAM 表(尽管 MyISAM 表不能完全称作“热备份”)。
- 包含详细的日志信息:更便于进行备份和恢复操作的调试。
-
限制:
- 额外的脚本消耗:因为 innobackupex 是一个脚本,相对会多出一些开销。
- 未来更新:使用 Perl 脚本可能在跨平台支持上有所限制,且潜在影响工具的维护和更新。
迁移与升级
事实上,随着时间的推移,innobackupex 已被官方弃用,Percona 强烈建议用户直接使用 XtraBackup。因此,在现代环境中,有可能需要将已有 innobackupex 脚本和操作迁移到使用 XtraBackup。
相关文章:
MySQL物理备份
目录 备份策略 全量备份 (Full Backup) 增量备份 (Incremental Backup) 差异备份 (Differential Backup) 使用 Percona XtraBackup 全量备份 步骤 1:全量备份 步骤 2:备份后处理(应用日志) 步骤 3:恢复备份 验…...
AWT常用组件
AWT中常用组件 前言一、基本组件组件名标签(Label类)Label类的构造方法注意要点 按钮(Button)Button的构造方法注意要点 文本框(TextField)TextField类的构造方法注意要点 文本域(TextArea)TextArea 的构造方法参数scrollbars的静态常量值 复选框&#x…...
CorelDRAW2024破解激活码序列号一步到位
亲们,今天给大家种草一个神奇的软件——CorelDRAW破解2024最新版!🎨这是一款专业级的矢量图形设计软件,无论你是平面设计师、插画师还是设计师,都能在这个软件中找到你需要的工具和功能。✨ 让我来给大家介绍一下这款软…...
Webpack前端打包工具详解
目录 Webpack前端打包工具详解一、Webpack 的作用二、Webpack 的安装和基本使用1. 安装 Webpack2. 创建 Webpack 配置文件3. 运行 Webpack 三、Webpack 核心概念1. 入口(Entry)2. 输出(Output)3. 加载器(Loaders&#…...
计网总结☞网络层
.................................................. 思维导图 ........................................................... 【Wan口和Lan口】 WAN口(Wide Area Network port): 1)用于连接外部网络,如互联…...
【全开源】云调查考试问卷系统(FastAdmin+ThinkPHP+Uniapp)
便捷、高效的在线调研与考试新选择 云调查考试问卷是一款基于FastAdminThinkPHPUniapp开发的问卷调查考试软件,可以自由让每一个用户自由发起调查问卷、考试问卷。发布的问卷允许控制问卷的搜集、回答等各个环节的设置,同时支持系统模板问卷ÿ…...
网络安全难学吗?2024该怎么系统学习网络安全?
学习网络安全需要循序渐进,由浅入深。很多人对网络安全进行了解以后,就打算开始学习网络安全,但是又不知道怎么去系统的学习。 网络安全本身的知识不难,但需要学习的内容有很多,其中包括Linux、数据库、渗透测试、等保…...
2 程序的灵魂—算法-2.4 怎样表示一个算法-2.4.6 用计算机语言表示算法
我们的任务是用计算机解题,就是用计算机实现算法; 用计算机语言表示算法必须严格遵循所用语言的语法规则。 【例 2.20】求 12345 用 C 语言表示。 main() {int i,t; t1; i2; while(i<5) {tt*i; ii1; } printf(“%d”,t); } 【例 2.21】求级数的…...
重生之我要精通JAVA--第八周笔记
文章目录 多线程线程的状态线程池自定义线程池最大并行数多线程小练习 网络编程BS架构优缺点CS架构优缺点三要素IP特殊IP常用的CMD命令 InetAddress类端口号协议UDP协议(重点)UDP三种通信方式 TCP协议(重点)三次握手四次挥手 反射…...
51单片机独立按键控制LED灯,按键按一次亮,再按一次灭
1、功能描述 独立按键控制LED灯,按键按一次亮,再按一次灭 2、实验原理 轻触按键:相当于是一种电子开关,按下时开关接通,松开时开关断开,实现原理是通过轻触按键内部的金属弹片受力弹动米实现接通和断开;…...
【上海大学计算机组成原理实验报告】七、程序转移机制
一、实验目的 学习实现程序转移的硬件机制。 掌握堆栈寄存器的使用。 二、实验原理 根据实验指导书的相关内容,实验箱系统的程序转移硬件机制在于,当LDPC有效时,如果此时DUBS上的值就是转移的目标地址,则此目标地址被打入PC&am…...
LLVM Cpu0 新后端7 第一部分 DAG调试 dot文件 Machine Pass
想好好熟悉一下llvm开发一个新后端都要干什么,于是参考了老师的系列文章: LLVM 后端实践笔记 代码在这里(还没来得及准备,先用网盘暂存一下): 链接: https://pan.baidu.com/s/1yLAtXs9XwtyEzYSlDCSlqw?…...
修复www服务trace漏洞
验证方式:curl -v -X TRACE ip:port,或使用其他接口调试工具如Postman 响应:状态行405 Method Not Allowed且响应体无内容 方案一:使用过滤器 若webserver是tomcat, 添加过滤器的方式有很多 Component public class TraceHttpMe…...
算法:101. 对称二叉树
对称二叉树 给你一个二叉树的根节点 root , 检查它是否轴对称。 示例 1: 输入:root [1,2,2,3,4,4,3] 输出:true示例 2: 输入:root [1,2,2,null,3,null,3] 输出:false提示: 树中节…...
wordpress 使用api发布文章
1.安装插件 在/wp-content/plugins/目录执行以下命令 $ sudo git clone https://github.com/WP-API/Basic-Auth.git 2.Python脚本 import requestsurl http://www.ziyuanwang.online/wp-json/wp/v2/postsuser adminpassword xxxxxheaders {Content-Type: application/j…...
《Brave New Words 》2.2 阅读理解的未来,让文字生动起来!
Part II: Giving Voice to the Social Sciences 第二部分:为社会科学发声 The Future of Reading Comprehension, Where Literature Comes Alive! 阅读理解的未来,让文字生动起来! Saanvi, a ninth grader in India who attends Khan World S…...
基于Java的超市进销存管理系统
开头语: 你好呀,我是计算机学长猫哥!如果有相关需求,文末可以找到我的联系方式。 开发语言: Java 数据库: MySQL 技术: Java JSP Servlet JavaBean 工具: IDEA/Eclipse、…...
Oracle 日志挖掘
oracle 11g 日志挖掘测试 需要开启补充日志 alter database add supplemental log data; SELECT SUPPLEMENTAL_LOG_DATA_MIN, SUPPLEMENTAL_LOG_DATA_PK, SUPPLEMENTAL_LOG_DATA_UI FROM V$DATABASE;在用户下执行一些删除,插入等操作 SQL> create table zxy( …...
翻转二叉树-力扣
翻转二叉树,通过前序遍历的顺序,从根节点开始,将节点的左右子节点一次进行交换即可。 /*** Definition for a binary tree node.* struct TreeNode {* int val;* TreeNode *left;* TreeNode *right;* TreeNode() : val(0), …...
办公风云颜值背后的职场正能量
办公风云:颜值背后的职场正能量当我们提到职场,脑海中浮现的往往是严肃的面孔、忙碌的身影和堆积如山的文件。但在这个看似单调的舞台上,总有一些人,用他们的颜值和才华,为我们上演了一场场别开生面的“大戏”。今天&a…...
ffmpeg将一个视频中的音频合并到另一个视频
ffmpeg -i input1.mp4 -i input2.mp4 -map 1:v -map 0:a -c:v copy -c:a aac -strict experimental output.mp4解释如下: -i input1.mp4:指定第一个输入文件input1.mp4,这是你要提取音频的文件。-i input2.mp4:指定第二个输入文件…...
Web前端管理系统项目:深度解析与实现之道
Web前端管理系统项目:深度解析与实现之道 在当今数字化时代,Web前端管理系统项目已成为企业信息化建设的核心组成部分。这类项目不仅涉及技术的深度和广度,更考验开发者的综合素质和创新能力。本文将从四个方面、五个方面、六个方面和七个方…...
C语言最终讲:预处理详解
C语言最终讲:预处理详解 1.预定义符号2.#define定义常量3.#define定义宏4.带有副作用的宏参数5.宏替换的规则6.宏和函数的对比6.1宏的优势6.1.1\符号 6.2宏的劣势 7.#和##7.1#运算符7.2##运算符 8.命名约定9.#undef10.命令行定义11.条件编译12.头文件的包含12.1本地…...
Mysql的底层实现逻辑
Mysql5.x和Mysql8性能的差异 整体性能有所提高, 在非高并发场景下,他们2这使用区别不大,性能没有明显的区别。 只有高并发时,mysql8才体现他的优势。 2. Mysql数据存储结构Innodb逻辑结构 数据选用B树结构存储数据࿰…...
Node安装配置
一、下载 Node官网下载地址:https://nodejs.org/en/ 二、安装 双击上面的msi扩展安装包开始安装,基本一路Next就行了 推荐安装目录自定义,最好不要放在C盘 检查安装是否成功 Win R 快捷键,输入 cmd 打开命令窗口输…...
Django里的ModelForm组件
ModelForm组件 自动生成HTML标签 自动读取关联数据表单验证 保留之前提交的数据 错误提示数据库进行:新建,修改 步骤如下: 创建类 # 在 views.py 文件里# 创建一个类 class AssetModelForm(forms.ModelForm):class Meta:model models.…...
深入理解C语言:main函数的奥秘
在C语言中,main函数是每个程序的入口点,起着至关重要的作用。本文将深入探讨main函数的工作原理,包括其参数、返回值、以及如何从main启动程序的执行。通过实际代码示例,读者将更深入地理解main函数在C语言编程中的核心地位。 第一…...
selenium自动化测试入门 —— Alert/Confirm/Prompt 弹出窗口处理!
一、Alert/Confirm/Prompt弹出窗口特征说明 Alert弹出窗口: 提示用户信息只有确认按钮,无法通过页面元素定位,不关闭窗口无法在页面上做其他操作。 Confirm 弹出窗口: 有确认和取消按钮,该弹出窗口无法用页面元素定…...
探索JavaScript 18:新特性全解析
JavaScript,作为全球最广泛使用的编程语言之一,每年的更新都备受开发者社区的关注。2023年,JavaScript的新版标准——ECMAScript 2023(也称为JavaScript 18)引入了多项激动人心的新特性,这些特性不仅优化了…...
Python第二语言(七、Python模块)
目录 1. 什么是模块 2. 基本语法 2.1 模块的导入方式 2.2 基本语法 import 模块名 2.3 基本语法 from 模块名 import 功能名 2.4 基本语法as 别名 3. 自定义模块 4. 调用自定义模块时,如何让其模块中的函数不被调用(__name__) 5. 调…...
南海网站推广/百度做广告怎么做
【摘要】在做国际化WEB项目的时候,遇到了一个根据用户浏览器所使用的自然语言切换默认语言版本的问题。于是,整理了这篇文章。 首先,W3Cschool关于Navigator的各个属性值说的很明确了,这里不再赘述。 然后,从各个浏览器…...
广告传媒公司网站怎么做/网络推广合作资源平台
传入消息的原始MIME树结构如下(使用email.iterators._structure(msg)):multipart/mixedtext/html (message)application/octet-stream (attachment 1)application/octet-stream (attachment 2)通过GMail进行回复,结果如下:multipart/alternativetext/pla…...
wordpress inaction/网站流量监控
linux修改bash目录How to test whether PATH has a specific directory in it in Bash on Linux?如何在Linux上的 Bash中测试PATH是否在其中具有特定目录? For example, how to test whether /usr/local/mytool/bin is in $PATH?例如,如何测试/usr/lo…...
怎么把电脑网站做服务器吗/网络平台营销
平时我们写代码呢,多数情况都是 流水线式 写代码,基本就可以实现业务逻辑了。 如何在写代码中找到乐趣呢 ,我觉得,最好的方式就是: 使用设计模式优化自己的业务代码 。今天跟大家聊聊日常工作中,我都使用过…...
展示型手机网站/微信营销的方法和技巧
2019独角兽企业重金招聘Python工程师标准>>> (1)Linux下各目录的作用 1)/bin/-----存放系统命令的目录,普通用户和超级用户都可以执行。不过放在/bin下的命令在单用户模式下也可以执行 2)/sbin/-----保存与…...
网站支付页面怎么做/网页设计免费模板
一、背景当进行深度学习任务如进行训练时,图片的大小可能导致显存不足,一个方法是对图片直接进行resize,这个会导致图片细节不足;另一个是对图片进行裁剪,裁剪成小的尺寸以送入模型训练,这也有一个缺点&…...