MySQL 全量、增量备份与恢复

1. 全量备份

  • 定义 :一次性备份数据库所有数据(表结构 + 数据),生成完整备份文件。
  • 优点:备份文件完整,恢复操作简单、速度快。
  • 缺点:数据量大时备份耗时、占用存储空间大,频繁全量备份效率低。
  • 适用场景:定期基础备份(如每周 / 每月一次)、新环境初始化、数据量较小的数据库。

2. 增量备份

  • 定义 :仅备份上一次备份(全量 / 增量)之后新增 / 修改的数据,依赖上一次备份的基准点。
  • 优点:备份速度快、占用空间小,适合高频备份。
  • 缺点:恢复复杂,需先恢复全量备份,再按顺序恢复所有增量备份;单个增量文件损坏会导致后续恢复失败。
  • 适用场景:日常高频备份(如每天 / 每小时一次)、数据更新频繁的数据库。

3. 备份与恢复核心工具

  • mysqldump:MySQL 官方逻辑备份工具,轻量易用,适合中小数据量,支持全量备份。
  • binlog(二进制日志) :MySQL 自带日志,记录所有数据修改操作,用于增量备份 + 基于时间点恢复
  • mysqlbinlog:解析 binlog 日志的工具,用于将增量日志还原为可执行 SQL。

全量备份

bash 复制代码
# 1. 备份所有数据库(系统库+业务库)
mysqldump -u用户名 -p密码 --all-databases > 备份文件路径/全量备份_$(date +%Y%m%d).sql

# 2. 备份指定单个数据库(推荐)
mysqldump -u用户名 -p密码 数据库名 > 备份文件路径/全量备份_数据库名_$(date +%Y%m%d).sql

# 3. 备份指定多个数据库
mysqldump -u用户名 -p密码 --databases 库1 库2 库3 > 全量备份_多库.sql

# 4. 带关键参数(生产环境推荐)
mysqldump -u用户名 -p密码 --single-transaction --flush-logs --master-data=2 数据库名 > 全量备份.sql
示例
bash 复制代码
# 备份test库,保存到/backup目录,文件名带日期
mysqldump -uroot -p123456 --single-transaction --flush-logs --master-data=2 test > /backup/full_test_20260330.sql
关键参数说明
  • --single-transaction:对 InnoDB 引擎做热备份,不锁表,不影响业务读写。
  • --flush-logs:备份前刷新 binlog 日志,新的增量操作写入新日志,方便区分备份节点。
  • --master-data=2:在备份文件中记录 binlog 位置,用于增量备份基准定位。

恢复

bash 复制代码
# 方式1:系统命令行直接恢复(无需登录MySQL)
mysql -u用户名 -p密码 目标数据库名 < 全量备份文件路径.sql

# 方式2:MySQL客户端内恢复(适合已登录场景)
mysql> use 目标数据库名;
mysql> source 全量备份文件绝对路径.sql;

示例

bash 复制代码
# 恢复test库数据
mysql -uroot -p123456 test < /backup/full_test_20260330.sql

增量备份与恢复

增量备份

MySQL 无直接增量备份命令,通过 binlog 日志实现增量备份

  1. 全量备份时执行--flush-logs,生成新的 binlog 日志。
  2. 全量备份后,所有数据修改操作都会记录在新 binlog 文件中,这些文件就是增量备份。
  3. 定期将新增的 binlog 文件复制到备份目录,完成增量备份。

增量备份

bash 复制代码
mysql> SHOW BINARY LOGS;

复制旧 binlog 文件到备份目录

bash 复制代码
cp /var/lib/mysql/mysql-bin.000001 /backup/increment_20260330_01.bin

先恢复最近一次全量备份 → 再按顺序恢复全量备份后的所有增量 binlog 日志

解析 binlog 日志

bash 复制代码
# 查看binlog内容(确认需要恢复的操作)
mysqlbinlog /var/lib/mysql/mysql-bin.000001

# 查看指定时间范围的日志(精准恢复)
mysqlbinlog --start-datetime="2026-03-30 10:00:00" --stop-datetime="2026-03-30 12:00:00" /var/lib/mysql/mysql-bin.000001

增量恢复命令

bash 复制代码
# 1. 基础恢复(整个binlog文件)
mysqlbinlog /backup/increment_000001.bin | mysql -u用户名 -p密码 数据库名

# 2. 按时间点恢复(避免误操作,精准恢复)
mysqlbinlog --start-datetime="2026-03-30 09:00:00" --stop-datetime="2026-03-30 18:00:00" /backup/increment_000001.bin | mysql -uroot -p123456 test

# 3. 按位置恢复(比时间更精准,查看binlog获取position值)
mysqlbinlog --start-position=107 --stop-position=1024 /backup/increment_000001.bin | mysql -uroot -p123456 test
相关推荐
2301_803875616 小时前
PHP 中处理会话数组时的类型错误解析与修复指南
jvm·数据库·python
m0_743623926 小时前
c++如何批量修改文件后缀名_std--filesystem--replace_extension【实战】
jvm·数据库·python
2501_914245936 小时前
CSS如何处理CSS变量作用域冲突_利用特定类名重写变量值
jvm·数据库·python
maqr_1108 小时前
MySQL数据库迁移到云端如何保障安全_数据加密与SSL连接配置
jvm·数据库·python
u0109147608 小时前
MySQL如何限制触发器递归调用的深度_防止触发器死循环方法
jvm·数据库·python
weixin_381288188 小时前
MySQL中如何使用HEX函数转换十六进制_MySQL进制转换函数
jvm·数据库·python
Deitymoon8 小时前
嵌入式数据库——SQLite基础
数据库·sqlite
YMatrix 官方技术社区8 小时前
美国·硅谷|YMatrix 即将亮相 Postgres Conference 2026,前瞻 AI 时代的数据基座
数据库·数据仓库·postgresql·时序数据库·ymatrix
bKYP953cL8 小时前
构建自己的AI编程助手:基于RAG的上下文感知实现方案
数据库·人工智能·ai编程
Bert.Cai8 小时前
MySQL DML简介
数据库·mysql