MYSQL-物理备份(xtrabackup)使用指南

数据库是一个系统(应用)最重要的资产之一,所以我们的数据库将从以下几个数据库来进行介绍。

MySQL (本章节)

PostgreSQL

MongoDB

Redis

Etcd

物理备份分两种情况:一种是直接复制库的物理文件(利用的是Linux复制文件的特性),但是这种情况一般需要在数据库服务停止的情况下进行,适合那种允许中断业务的情况进行。另外一种就是利用开源工具XtraBackup进行备份,因为他具有增量备份的能力,所有部分云厂商的备份也会基于类似的操作。

备份

安装

复制代码
# 安装 Percona 仓库sudo yum install https://repo.percona.com/yum/percona-release-latest.noarch.rpmsudo percona-release enable tools releasesudo yum install percona-xtrabackup-24

全量备份​​​​​​​

复制代码
# 基本全量备份xtrabackup --backup --target-dir=/path/to/backup --user=root --password=your_password
# 完整示例xtrabackup \    --backup \    --target-dir=/backup/mysql/full_$(date +%Y%m%d_%H%M%S) \    --user=root \    --password=your_password \    --socket=/var/lib/mysql/mysql.sock \    --parallel=4 \    --compress​​​​​​

251013 22:26:57 Executing UNLOCK TABLES251013 22:26:57 All tables unlocked251013 22:26:57 [00] Compressing ib_buffer_pool to /backup/mysql/full_20251013_222642/ib_buffer_pool.qp251013 22:26:57 [00]        ...done251013 22:26:57 Backup created in directory '/backup/mysql/full_20251013_222642/'MySQL binlog position: filename 'mysql-bin.000014', position '154'251013 22:26:57 [00] Compressing /backup/mysql/full_20251013_222642/backup-my.cnf.qp251013 22:26:57 [00]        ...done251013 22:26:57 [00] Compressing /backup/mysql/full_20251013_222642/xtrabackup_info.qp251013 22:26:57 [00]        ...donextrabackup: Transaction log of lsn (1079467870) to (1079467879) was copied.251013 22:26:58 completed OK!

备份完成内容

可以和数据存储的的数据进行比对,你会发现具体的某个库下面的实际内容和数据目录甚至是一模一样。​​​​​​​

复制代码
[root@localhost xback]# lltotal 77876-rw-r----- 1 root root      487 Sep 28 00:45 backup-my.cnf-rw-r----- 1 root root      790 Sep 28 00:45 ib_buffer_pool-rw-r----- 1 root root 79691776 Sep 28 00:45 ibdata1drwxr-x--- 2 root root     4096 Sep 28 00:45 mysqldrwxr-x--- 2 root root     8192 Sep 28 00:45 performance_schemadrwxr-x--- 2 root root     8192 Sep 28 00:45 sysdrwxr-x--- 2 root root      214 Sep 28 00:45 test_db-rw-r----- 1 root root       21 Sep 28 00:45 xtrabackup_binlog_info-rw-r----- 1 root root      144 Sep 28 00:45 xtrabackup_checkpoints-rw-r----- 1 root root      493 Sep 28 00:45 xtrabackup_info-rw-r----- 1 root root     2560 Sep 28 00:45 xtrabackup_logfile

备份单个库​​​​​​​

复制代码
# 备份指定数据库的所有表xtrabackup --backup \    --target-dir=/backup/database1_full \    --user=root \    --password='@!qaz2WSX' \    --tables="^database1[.].*"
# 示例:备份 db1 数据库xtrabackup --backup \    --target-dir=/backup/db1_full \    --user=root \    --password='@!qaz2WSX' \    --tables="^db1[.].*"

第一次增量备份​​​​​​​

复制代码
FULL_BACKUP_DIR="/backup/mysql/full_20251013_222642" && \INC_BACKUP_DIR1="/backup/mysql/inc1_$(date +%Y%m%d_%H%M%S)" && \xtrabackup --backup --target-dir=$INC_BACKUP_DIR1 --incremental-basedir=$FULL_BACKUP_DIR --user=root --password='@!qaz2WSX' --socket=/var/lib/mysql/mysql.sock && \echo "第一次增量备份完成: $INC_BACKUP_DIR1"

第二次增加备份​​​​​​​

复制代码
FULL_BACKUP_DIR="/backup/mysql/full_20251013_222642" && \INC_BACKUP_DIR1="/backup/mysql/inc1_$(date +%Y%m%d_%H%M%S)" && \xtrabackup --backup --target-dir=$INC_BACKUP_DIR1 --incremental-basedir=$FULL_BACKUP_DIR --user=root --password='@!qaz2WSX' --socket=/var/lib/mysql/mysql.sock && \echo "第一次增量备份完成: $INC_BACKUP_DIR1"

注意:这里的备份需要上一次备份具体目录。

还原

合并备份​​​​​​​

复制代码
#!/bin/bash
# 备份目录FULL_BACKUP_DIR="/backup/mysql/full_20251013_222642"INC_BACKUP_DIR1="/backup/mysql/inc1_20251013_223918"INC_BACKUP_DIR2="/backup/mysql/inc2_20251013_224134"  # 您的第二次增量备份目录
echo "开始合并还原全量+增量备份..."
# 步骤1: 准备全量备份(应用redo日志)echo "1. 准备全量备份..."xtrabackup --prepare --apply-log-only --target-dir=$FULL_BACKUP_DIR
# 步骤2: 合并第一次增量备份echo "2. 合并第一次增量备份..."xtrabackup --prepare --apply-log-only --target-dir=$FULL_BACKUP_DIR \    --incremental-dir=$INC_BACKUP_DIR1
# 步骤3: 合并第二次增量备份(最后一步不使用--apply-log-only)echo "3. 合并第二次增量备份..."xtrabackup --prepare --target-dir=$FULL_BACKUP_DIR \    --incremental-dir=$INC_BACKUP_DIR2
echo "合并完成!现在可以执行恢复操作..."

还原​​​​​​​

复制代码
# 1. 停止MySQLsystemctl stop mysql
# 2. 清空数据目录(确保已备份重要数据)rm -rf /var/lib/mysql/*
# 3. 执行还原xtrabackup --copy-back --target-dir=/backup/mysql/full_20251013_222642
# 4. 设置权限chown -R mysql:mysql /var/lib/mysql
# 5. 启动MySQLsystemctl start mysql

这样我们就完成了使用增量物理备份工具(xtrabackup),从备份到还原的全部操作,当然这里只演示步骤,真实环境还需要考虑很多因素,会更复杂。

相关推荐
银发控、8 小时前
MySQL联合索引
数据库·mysql
予枫的编程笔记8 小时前
【MySQL修炼篇】从踩坑到精通:事务隔离级别的3大异常(脏读/幻读/不可重复读)解决方案
数据库·mysql·后端开发·数据库事务·事务隔离级别·rr级别·脏读幻读不可重复读
一起养小猫9 小时前
Flutter for OpenHarmony 实战:记账应用数据统计与可视化
开发语言·jvm·数据库·flutter·信息可视化·harmonyos
世界尽头与你9 小时前
(修复方案)CVE-2023-22047: Oracle PeopleSoft Enterprise PeopleTools 未授权访问漏洞
数据库·安全·oracle·渗透测试
韩立学长9 小时前
【开题答辩实录分享】以《智能大学宿舍管理系统的设计与实现》为例进行选题答辩实录分享
数据库·spring boot·后端
Henry Zhu12310 小时前
数据库(五):反规范化
数据库
Mr_Xuhhh10 小时前
MySQL函数详解:日期、字符串、数学及其他常用函数
java·数据库·sql
he___H11 小时前
Redis高级数据类型
数据库·redis·缓存
霖霖总总11 小时前
[小技巧60]深入解析 MySQL Online DDL:MySQL Online DDL、pt-osc 与 gh-ost 机制与最佳实践
数据库·mysql
爱学习的阿磊11 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python