0

0

mysql如何使用物理备份_mysql文件级备份方式

P粉602998670

P粉602998670

发布时间:2026-03-03 10:11:04

|

589人浏览过

|

来源于php中文网

原创

物理备份不一定需停库,但多数场景需停库;唯一热备方案是percona xtrabackup或mysqlbackup,通过监听redo log与拷贝脏页实现一致性,备份时加全局读锁仅阻塞写操作。

mysql如何使用物理备份_mysql文件级备份方式

物理备份必须停库吗?

不一定,但绝大多数场景下需要停库。MySQL 的物理备份本质是直接复制数据文件(如 ibdata1.ibdmysql-bin.* 等),如果实例正在运行且有未刷盘的脏页、未提交事务或正在写入的 redo log,直接拷贝会导致文件状态不一致,恢复后大概率报错 Tablespace is missing for table 或启动失败。

唯一可不停机的物理备份方式是使用 mysqlbackup(MySQL Enterprise Backup)或 Percona XtraBackup —— 它们通过监听 redo log 流 + 拷贝内存中脏页的方式实现一致性热备。开源环境基本只用后者。

  • mysqld 进程必须可访问,且用户需有 RELOADPROCESSSUPER 权限
  • 备份期间会加全局读锁(FLUSH TABLES WITH READ LOCK),只阻塞写,不影响读,所以“热”是相对的
  • 备份完成后会自动释放锁,但锁持有时间取决于数据量和 IO 速度

用 Percona XtraBackup 做一次完整备份

这是目前最主流、最可靠的 MySQL 物理备份方案,支持 MySQL 5.7/8.0、Percona Server、MariaDB。注意:XtraBackup 8.0+ 只兼容 MySQL 8.0,若用 MySQL 5.7 必须用 XtraBackup 2.4。

安装后执行:

xbbackup --user=root --password=xxx --backup --target-dir=/backup/full_$(date +%F)

关键点:

  • --backup 表示执行备份(不是还原);--prepare 才是还原前的恢复准备步骤
  • --target-dir 必须是空目录,不能是已存在的备份路径
  • 默认会备份所有数据库,加 --databases="db1 db2" 可指定库
  • 备份过程生成 xtrabackup_binlog_infoxtrabackup_checkpoints,记录 binlog 位置和 LSN,用于后续增备或搭建从库

如何验证物理备份是否可用?

不能只看文件有没有拷出来,必须走完「恢复流程」并验证能启动、能查数据。常见误判是备份成功了,但没做 --prepare 就直接复制到 datadir 启动,结果报 InnoDB: Operating system error number 2 in a file operation

互连在线双语商务版
互连在线双语商务版

全自动化、全智能的在线方式管理、维护、更新的网站管理系统主要功能如下:一、系统管理:管理员管理,可以新增管理员及修改管理员密码;数据库备份,为保证您的数据安全本系统采用了数据库备份功能;上传文件管理,管理你增加产品时上传的图片及其他文件。二、企业信息:可设置修改企业的各类信息及介绍。 三、产品管理:产品类别新增修改管理,产品添加修改以及产品的审核。四、订单管理:查看订单的详细信息及订单处理。 五、

下载

正确验证步骤:

  • 先执行 xbbackup --prepare --target-dir=/backup/full_2024-06-01(该操作不依赖 MySQL 实例)
  • 停止目标 MySQL:systemctl stop mysqld
  • 清空原 datadir(如 /var/lib/mysql),再用 rsync -av /backup/full_2024-06-01/ /var/lib/mysql/
  • 改权限:chown -R mysql:mysql /var/lib/mysql
  • 启动:systemctl start mysqld,观察错误日志是否有 InnoDB: Starting crash recoveryready for connections

如果启动成功,连上去执行 SELECT COUNT(*) FROM some_table,确认数据行数与备份前一致。

增量备份怎么接在全量后面?

增量备份依赖全量备份的 to_lsn 值,这个值存在 xtrabackup_checkpoints 文件里。每次增备都必须基于上一次(全量或上次增备)的 prepared 状态目录来打。

实操顺序:

  • 全备后先 --prepare(此时 backup_type = full-prepared
  • 等一段时间后,执行增备:xbbackup --incremental --incremental-basedir=/backup/full_2024-06-01 --target-dir=/backup/inc_2024-06-02
  • 增备也必须 --prepare,但命令稍不同:xbbackup --prepare --apply-log-only --target-dir=/backup/full_2024-06-01(先合并全备),再 xbbackup --prepare --apply-log-only --target-dir=/backup/full_2024-06-01 --incremental-dir=/backup/inc_2024-06-02
  • 最后去掉 --apply-log-only 再跑一次 --prepare,得到最终可恢复的全量目录

漏掉 --apply-log-only 会导致后续增量无法合并,报错 lsn is higher than the last checkpoint

物理备份真正难的不是执行命令,而是理解每个环节的 LSN 链路、锁行为和 prepare 时机。很多故障不是备份失败,而是跳过了验证或混淆了 prepare 阶段——比如把未 prepare 的增备目录直接当全量用了。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
mysql修改数据表名
mysql修改数据表名

MySQL修改数据表:1、首先查看数据库中所有的表,代码为:‘SHOW TABLES;’;2、修改表名,代码为:‘ALTER TABLE 旧表名 RENAME [TO] 新表名;’。php中文网还提供MySQL的相关下载、相关课程等内容,供大家免费下载使用。

682

2023.06.20

MySQL创建存储过程
MySQL创建存储过程

存储程序可以分为存储过程和函数,MySQL中创建存储过程和函数使用的语句分别为CREATE PROCEDURE和CREATE FUNCTION。使用CALL语句调用存储过程智能用输出变量返回值。函数可以从语句外调用(通过引用函数名),也能返回标量值。存储过程也可以调用其他存储过程。php中文网还提供MySQL创建存储过程的相关下载、相关课程等内容,供大家免费下载使用。

452

2023.06.21

mongodb和mysql的区别
mongodb和mysql的区别

mongodb和mysql的区别:1、数据模型;2、查询语言;3、扩展性和性能;4、可靠性。本专题为大家提供mongodb和mysql的区别的相关的文章、下载、课程内容,供大家免费下载体验。

286

2023.07.18

mysql密码忘了怎么查看
mysql密码忘了怎么查看

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql密码忘了怎么办呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

519

2023.07.19

mysql创建数据库
mysql创建数据库

MySQL是一个关系型数据库管理系统,由瑞典MySQL AB 公司开发,属于 Oracle 旗下产品。MySQL 是最流行的关系型数据库管理系统之一,在 WEB 应用方面,MySQL是最好的 RDBMS 应用软件之一。那么mysql怎么创建数据库呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

265

2023.07.25

mysql默认事务隔离级别
mysql默认事务隔离级别

MySQL是一种广泛使用的关系型数据库管理系统,它支持事务处理。事务是一组数据库操作,它们作为一个逻辑单元被一起执行。为了保证事务的一致性和隔离性,MySQL提供了不同的事务隔离级别。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

392

2023.08.08

sqlserver和mysql区别
sqlserver和mysql区别

SQL Server和MySQL是两种广泛使用的关系型数据库管理系统。它们具有相似的功能和用途,但在某些方面存在一些显著的区别。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

541

2023.08.11

mysql忘记密码
mysql忘记密码

MySQL是一种关系型数据库管理系统,关系数据库将数据保存在不同的表中,而不是将所有数据放在一个大仓库内,这样就增加了速度并提高了灵活性。那么忘记mysql密码我们该怎么解决呢?php中文网给大家带来了相关的教程以及其他关于mysql的文章,欢迎大家前来学习阅读。

665

2023.08.14

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

3

2026.03.03

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.4万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 842人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号