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),从备份到还原的全部操作,当然这里只演示步骤,真实环境还需要考虑很多因素,会更复杂。

相关推荐
爱可生开源社区13 小时前
医疗业务系统升级,这家三甲医院为何牵手 OceanBase?(SQLServer->OceanBase)
数据库
huihuihuanhuan.xin13 小时前
后端八股之mysql
数据库·mysql
洋不写bug14 小时前
数据库数据类型,数据值类型,字符串类型,日期类型详解
数据库·mysql
Paraverse_徐志斌14 小时前
RAG架构(检索增强生成)与向量数据库
数据库·ai·llm·embedding·milvus·rag
NineData15 小时前
NineData将亮相第27届GOPS全球运维大会,并带来技术演讲
运维·数据库·ninedata·智能·ai agent·数据管理工具·gops全球运维大会
Java水解15 小时前
MySQL 中 ROW_NUMBER() 函数详解
后端·mysql
不良人天码星15 小时前
谈谈redis的持久化
数据库·redis·缓存
huibin14785236916 小时前
不能识别adb/usb口记录
android·adb
qq_4798754316 小时前
TimerFd & Epoll
java·服务器·数据库