news 2026/4/23 13:27:46

mysqldump 备份恢复,从单库到全库恢复实操

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
mysqldump 备份恢复,从单库到全库恢复实操

一、恢复前的准备工作

在执行恢复操作前,务必做好以下检查,避免数据丢失或恢复失败:

  1. 确认目标 MySQL 服务正常运行(systemctl status mysqld);
  2. 验证备份文件的有效性:可通过cat 备份文件.sql | head -20查看是否有正常的 SQL 语句(如CREATE DATABASEINSERT);
  3. 恢复前建议备份当前数据库(避免覆盖错误),生产环境优先在测试库验证后再操作;
  4. 确保执行恢复的 MySQL 用户有CREATEINSERTALTER等权限(推荐用 root 用户)。

二、基础恢复语法

mysqldump生成的备份文件本质是 SQL 脚本,恢复核心是通过mysql命令执行该脚本,基础语法:

mysql[连接参数][目标库名]<备份文件路径/文件名.sql

核心连接参数和mysqldump一致:-u(用户名)、-p(密码)、-h(远程IP)、-P(端口)。

三、不同场景的恢复实操

1. 恢复单库备份(最常用)

适用于用mysqldump -u -p 单库名 > 备份文件.sql生成的备份文件。

场景1:目标库已存在(直接覆盖/追加数据)
# 恢复 test_db 库(需提前确保 test_db 库存在)mysql -uroot -p test_db</backup/mysql/test_db_20260113.sql

执行后输入 MySQL 密码,脚本会自动执行,将备份的表结构和数据导入test_db库。

场景2:目标库不存在(先建库再恢复)

如果删除了test_db库,需先创建空库再恢复:

# 1. 登录 MySQL 创建空库mysql -uroot -p -e"CREATE DATABASE IF NOT EXISTS test_db DEFAULT CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;"# 2. 恢复数据到新建的库mysql -uroot -p test_db</backup/mysql/test_db_20260113.sql

2. 恢复多库备份

适用于用--databases参数备份的多库文件(包含CREATE DATABASE语句),无需提前建库:

# 恢复 test_db1、test_db2 多个库(备份文件已包含建库语句)mysql -uroot -p</backup/mysql/multi_db_20260113.sql

关键说明:多库备份文件里会有CREATE DATABASEUSE 库名语句,因此恢复时不需要指定具体库名,直接执行即可。

3. 恢复全库备份

适用于用-A/--all-databases备份的全库文件,恢复后会覆盖所有现有数据库(谨慎操作):

# 恢复所有数据库(包含系统库,生产环境需确认)mysql -uroot -p</backup/mysql/full_db_20260113.sql

注意:全库恢复会覆盖mysql系统库(包含用户、权限),如果是跨服务器恢复,建议先备份目标服务器的mysql库。

4. 恢复压缩的备份文件(.sql.gz)

生产环境常用gzip压缩备份,恢复时无需手动解压,可通过管道直接执行:

# 直接恢复 gzip 压缩的备份文件(单库)gzip-dc /backup/mysql/test_db_20260113.sql.gz|mysql -uroot -p test_db# 恢复压缩的全库备份gzip-dc /backup/mysql/full_db_20260113.sql.gz|mysql -uroot -p

参数解析:-dc表示解压并输出到标准输出,避免生成解压后的临时文件,节省磁盘空间。

5. 恢复指定表(精准恢复)

如果只需恢复备份文件中的某一张表(如test_db库的user表),可通过grep筛选 SQL 语句:

# 从单库备份中提取 user 表的结构和数据并恢复cat/backup/mysql/test_db_20260113.sql|grep-E"CREATE TABLE \`user\`|INSERT INTO \`user\`"|mysql -uroot -p test_db

或更精准的方式(先解压压缩包再筛选):

# 从压缩包中提取指定表gzip-dc /backup/mysql/test_db_20260113.sql.gz|grep-E"CREATE TABLE \`user\`|INSERT INTO \`user\`"|mysql -uroot -p test_db

四、恢复常见问题与避坑

  1. 字符集不一致:恢复后中文乱码,需确保备份和恢复时数据库字符集一致,可在mysql命令后加--default-character-set=utf8mb4
    mysql -uroot -p --default-character-set=utf8mb4 test_db<备份文件.sql
  2. 权限不足:提示Access denied,需给用户赋权:
    GRANTALLPRIVILEGESON*.*TO'用户名'@'localhost'IDENTIFIEDBY'密码';FLUSHPRIVILEGES;
  3. 表已存在:提示Table 'xxx' already exists,可先删除表再恢复(谨慎),或在备份文件中添加DROP TABLE IF EXISTS(备份时加--add-drop-table参数)。
  4. 远程恢复:恢复到远程 MySQL 服务器,需指定-h-P
    mysql -uroot -p -h192.168.1.100 -P3306 test_db</backup/mysql/test_db_20260113.sql
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 12:58:39

Go语言系统精讲:从入门到工程实践的体系化学习指南

Go语言系统精讲&#xff1a;从入门到工程实践的体系化学习指南 “兼具Python的开发速度和C的性能”——这不仅是Go语言的设计目标&#xff0c;更是它征服全球开发者的核心魅力。 作为一名CSDN技术博主&#xff0c;我深知学习一门新语言时系统化学习路径的重要性。面对网上零散的…

作者头像 李华
网站建设 2026/4/23 12:42:00

拆解 DDoS 攻击套路:抗 D 防护的主动防御与应急响应机制

在数字化业务高速运转的今天&#xff0c;DDoS攻击已成为网络安全领域的“常客”——小到中小企业业务中断&#xff0c;大到大型平台瘫痪&#xff0c;攻击不仅会直接造成经济损失&#xff0c;还会摧毁用户信任。很多运维人员在应对攻击时&#xff0c;常陷入“被动防御、事后补救…

作者头像 李华
网站建设 2026/4/16 16:08:51

新年第一缕阳光,在牯牛山之巅迎接

云南那些超厉害的美食&#xff0c;以及昆明周边元旦徒步的隐秘之地&#xff0c;共同描绘出极具野趣的冬日玩法&#xff0c;既可以满足舌尖上的冒险&#xff0c;还能够遇到限定的自然风光。云南人&#xff0c;简直可以说好像处在食物链顶端&#xff0c;餐桌上满满的都是山野气息…

作者头像 李华
网站建设 2026/4/18 3:39:22

计算机专业学生考研失败如何快速就业?二战VS就业?

计算机专业学生考研失败如何快速就业&#xff1f;二战VS就业&#xff1f; 作为计算机专业的学生&#xff0c;面对考研失利后的抉择&#xff0c;需要结合个人情况和行业特点理性分析。以下是分步建议&#xff1a; 第一步&#xff1a;自我评估 技术能力盘点 梳理已掌握的编程语言…

作者头像 李华
网站建设 2026/4/19 5:30:09

- Kappa架构:利用Kafka锻造的屠龙刀

你好&#xff0c;我是程序员贵哥。 今天我要分享的主题是Kappa架构。 同样身为大规模数据处理架构&#xff0c;Kappa架构这把利用Kafka锻造的“屠龙刀”&#xff0c;它与Lambda架构的不同之处在哪里呢&#xff1f; 上一讲中&#xff0c;我讲述了在处理大规模数据时所用到经典架…

作者头像 李华
网站建设 2026/4/22 0:05:29

MediaPipe Hands实战:AR/VR手势交互系统

MediaPipe Hands实战&#xff1a;AR/VR手势交互系统 1. 引言&#xff1a;AI 手势识别与追踪的现实价值 随着增强现实&#xff08;AR&#xff09;和虚拟现实&#xff08;VR&#xff09;技术的快速发展&#xff0c;传统输入方式如键盘、鼠标、手柄已难以满足沉浸式交互的需求。…

作者头像 李华