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[密码]

验证数据
检查数据库是否已经成功恢复,运行一些查询来验证数据的完整性。

 

 

增量备份

概述步骤

  1. 全量备份:创建一个基础备份,包含当前数据库的所有数据。
  2. 第一次增量备份:基于全量备份创建增量备份,包含自全量备份以来的所有更改。
  3. 第二次增量备份:基于第一次增量备份创建增量备份,包含自第一次增量备份以来的所有更改。
  4. 预处理全量备份:将全量备份应用日志,准备合并增量备份。
  5. 应用第一次增量备份:合并第一次增量备份到全量备份中。
  6. 应用第二次增量备份:合并第二次增量备份到全量备份中。
  7. 最终预处理:确保所有更改应用,使得备份达到一致状态。
  8. 恢复备份到 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)是指在某个基准点(通常是全量备份)之后,只备份自基准点以来发生了变化的所有数据。与增量备份不同的是,差异备份总是基于同一个基准点,而增量备份则是基于上一个备份。

概述步骤

  1. 进行全量备份:创建初始的全量备份,作为基准点。
  2. 进行第一次差异备份:自全量备份以来的所有变化。
  3. 进行第二次差异备份:自全量备份以来的所有变化。
  4. 预处理全量备份:准备和合并差异备份。
  5. 应用第一次差异备份:将第一次差异备份合并到全量备份。
  6. 应用第二次差异备份:将第二次差异备份合并到全量备份。
  7. 最终预处理:确保所有更改应用,使得备份达到一致状态。
  8. 恢复备份到 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。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/25955.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

大模型基础——从零实现一个Transformer(2)

大模型基础——从零实现一个Transformer(1) 一、引言 上一章主要实现了一下Transformer里面的BPE算法和 Embedding模块定义 本章主要讲一下 Transformer里面的位置编码以及多头注意力 二、位置编码 2.1正弦位置编码(Sinusoidal Position Encoding) 其中: pos&…

持续总结中!2024年面试必问 20 道分布式、微服务面试题(七)

上一篇地址:持续总结中!2024年面试必问 20 道分布式、微服务面试题(六)-CSDN博客 十三、请解释什么是服务网格(Service Mesh)? 服务网格(Service Mesh)是一种用于处理服…

线程知识点总结

Java线程是Java并发编程中的核心概念之一,它允许程序同时执行多个任务。以下是关于Java线程的一些关键知识点总结: 1. 线程的创建与启动 继承Thread类:创建一个新的类继承Thread类,并重写其run()方法。通过创建该类的实例并调用st…

TypeScript基础教程学习

菜鸟教程 TypeScript基础类型 数字类型 number 双精度 64 位浮点值。它可以用来表示整数和分数。 let binaryLiteral: number 0b1010; // 二进制 let octalLiteral: number 0o744; // 八进制 let decLiteral: number 6; // 十进制 let hexLiteral: number 0xf00d…

从信号灯到泊车位,ARMxy如何重塑城市交通智能化

城市智能交通系统的高效运行对于缓解交通拥堵、提高出行安全及优化城市管理至关重要。ARMxy工业计算机,作为这一领域内的技术先锋,正以其强大的性能和灵活性,悄然推动着交通管理的智能化升级。 智能信号控制的精细化管理 想象一下&#xff0…

【C语言】11.字符函数和字符串函数

文章目录 1.字符分类函数2.字符转换函数3.strlen的使用和模拟实现4.strcpy的使用和模拟实现5.strcat的使用和模拟实现6.strcmp的使用和模拟实现7.strncpy函数的使用8.strncat函数的使用9.strncmp函数的使用10.strstr的使用和模拟实现11.strtok函数的使用12.strerror函数的使用 …

视频修复工具,模糊视频变清晰!

老旧视频画面效果差,视频效果模糊。我们经常找不到一个好的工具来让视频更清晰,并把它变成高清画质。相信很多网友都会有这个需求,尤其是视频剪辑行业的网友,经常会遇到这个问题。今天给大家分享一个可以把模糊视频修复清晰的工具…

cnvd_2015_07557-redis未授权访问rce漏洞复现-vulfocus复现

1.复现环境与工具 环境是在vulfocus上面 工具:GitHub - vulhub/redis-rogue-getshell: redis 4.x/5.x master/slave getshell module 参考攻击使用方式与原理:https://vulhub.org/#/environments/redis/4-unacc/ 2.复现 需要一个外网的服务器做&…

《TCP/IP网络编程》(第十四章)多播与广播

当需要向多个用户发送多媒体信息时,如果使用TCP套接字,则需要维护与用户数量相等的套接字;如果使用之前学习的UDP,传输次数也需要和用户数量相同。 所以为了解决这些问题,可以采用多播和广播技术,这样只需要…

Python学习打卡:day02

day2 笔记来源于:黑马程序员python教程,8天python从入门到精通,学python看这套就够了 8、字符串的三种定义方式 字符串在Python中有多种定义形式 单引号定义法: name 黑马程序员双引号定义法: name "黑马程序…

网安面试题总结_1

#创作灵感# 助力网安人员顺利面试 等保测评 等保测评一般分成五个阶段,定级、备案、测评、整改、监督检查。 外网 外网打点的基本流程主要分为:靶标确认、信息收集、漏洞探测、漏洞利用、权限获取,其最终目的是为了获取靶标的系统权限/关…

Spring Boot中Excel的导入导出的实现之Apache POI框架使用教程

文章目录 前言一、Apache POI 是什么?二、使用 Apache POI 实现 Excel 的导入和导出① 导入 Excel1. 添加依赖2. 编写导入逻辑3. 在 Controller 中处理上传请求 ② 导出 Excel1. 添加依赖2. 编写导出逻辑3. 在 Controller 中处理导出请求 总结 前言 在 Spring Boot …

代码随想录算法训练营第四十四天 | 01背包问题理论基础、01背包问题滚动数组、416. 分割等和子集

背包问题其实有很多种,01背包是最基础也是最经典的,软工计科学生一定要掌握的。 01背包问题 代码随想录 视频讲解:带你学透0-1背包问题!| 关于背包问题,你不清楚的地方,这里都讲了!| 动态规划经…

C++11:列表初始化 初始化列表initializer_list decltype关键字

目录 前言 列表初始化 初始化列表initializer_list decltype关键字 左值和右值 move 前言 2003年C标准委员会曾经提交了一份技术勘误表(简称TC1),使得C03这个名字取代了C98成为了C11前最新的C标准名称。不过由于C03主要是对C98标准中的…

网络安全在个人生活中具体有哪些常见的应用场景?

网络安全在个人生活中的应用场景非常广泛,以下是一些常见的例子: 1. 个人隐私保护:网络安全可以帮助保护个人的隐私信息,如银行账户、身份证号、联系方式等,防止被黑客窃取或滥用。 2. 电子商务:在进行在…

认识和使用 Vite 环境变量配置,优化定制化开发体验

Vite 官方中文文档:https://cn.vitejs.dev/ 环境变量 Vite 内置的环境变量如下: {"MODE": "development", // 应用的运行环境"BASE_URL": "/", // 部署应用时使用的 URL 前缀"PROD": false, //应用…

国外媒体软文发稿-引时代潮流-助力跨国企业蓬勃发展

大舍传媒:开疆拓土,引领传媒新潮流 随着全球经济的一体化和信息技术的高速发展,跨国企业在国际市场上的竞争越来越激烈。这也给跨国企业带来了巨大的机遇和挑战。在这个时代背景下,大舍传媒凭借其独特的优势和创新的服务模式&…

分布式数据库中,如何正确的将数据分片?

前面我们了解了分布式数据库的架构,知道各类分布式数据库都离不开计算层、存储层、元数据层这三层关系。另外,很重要的一点是,了解了分布式数据库是把数据打散存储在一个个分片中。在基于MySQL 的分布式数据库架构中,分片就存在于 MySQL 实例中。 本篇文章,我们就来了解一…

市值超越苹果,英伟达的AI崛起与天润融通的数智化转型

Agent,开启客户服务新时代。 世界商业格局又迎来一个历史性时刻。 北京时间6月6日,人工智能芯片巨头英伟达(NVDA)收涨5.16%,总市值达到3.01万亿美元,正式超越苹果公司,成为仅次于微软&#xf…

IDEA启动项目报java.lang.OutOfMemoryError: GC overhead limit exceeded

idea编译项目时报j ava.lang.OutOfMemoryError: GC overhead limit exceeded错误,教你两步搞定! 第一步:打开help -> Edit Custom VM Options ,修改xms和xmx的大小,如下图: 第二步:File -> Settings…