首页 > 运维 > linux运维 > 正文

Linux如何备份与恢复数据库_Linuxmysqldump备份恢复指南

舞夢輝影
发布: 2025-11-22 22:58:02
原创
515人浏览过
使用mysqldump可高效备份恢复MySQL数据。1. 备份单库:mysqldump -u 用户名 -p 数据库名 > 文件.sql;2. 多库备份加--databases;3. 全库用--all-databases;4. 仅结构加--no-data;5. 命名加时间戳便于管理;恢复前确保库存在,再用mysql -u 用户名 -p DB < backup.sql导入,建议用.my.cnf存凭证提安全,大库优化可用--single-transaction和--quick,注意字符集一致防乱码。

linux如何备份与恢复数据库_linuxmysqldump备份恢复指南

在Linux环境下,使用mysqldump进行MySQL数据库的备份与恢复是一种常见且高效的方法。它能导出数据库为SQL脚本文件,便于存档、迁移或灾难恢复。下面详细介绍如何进行备份与恢复操作。

一、使用mysqldump进行数据库备份

mysqldump 是MySQL自带的逻辑备份工具,可以将数据库结构和数据导出为SQL语句。

1. 备份单个数据库

mysqldump -u 用户名 -p 数据库名 > 备份文件名.sql
登录后复制

例如:

mysqldump -u root -p mydb > mydb_backup.sql
登录后复制

执行后会提示输入密码,成功后生成mydb_backup.sql文件。

2. 备份多个数据库

mysqldump -u 用户名 -p --databases db1 db2 > 多库备份.sql
登录后复制

3. 备份所有数据库

mysqldump -u root -p --all-databases > all_databases.sql
登录后复制

4. 仅备份表结构(不包含数据)

mysqldump -u root -p --no-data 数据库名 > structure_only.sql
登录后复制

5. 添加时间戳命名备份文件

便于管理不同时间的备份:

mysqldump -u root -p mydb > mydb_$(date +%Y%m%d_%H%M%S).sql
登录后复制

二、数据库恢复操作

恢复是将备份的SQL文件重新导入到MySQL数据库中。

1. 恢复前准备

确保目标数据库存在,如不存在可创建:

mysql -u root -p -e "CREATE DATABASE IF NOT EXISTS mydb;"
登录后复制

2. 恢复单个数据库

mysql -u 用户名 -p 数据库名 < 备份文件名.sql
登录后复制

示例:

mysql -u root -p mydb < mydb_backup.sql
登录后复制

3. 恢复所有数据库

适用于--all-databases方式备份的文件:

双轨制会员管理系统 v9.1
双轨制会员管理系统 v9.1

双轨制会员管理系统是一个以asp+access进行开发的双轨制直销系统源码,要求很低,容易维护。 后台路径:/admin 后台用户名和密码均为:admin 9.1版更新内容: 1、增加了操作余额前自动备份数据库,如果操作成功,则自动删除备份的数据库;如果操作有页面错误导致不成功,则会自动恢复到备份的数据库。这样运行过程中,即使是程序错误,也不用担心数据丢失了。 2、增加会员登录首

双轨制会员管理系统 v9.1 843
查看详情 双轨制会员管理系统 v9.1
mysql -u root -p < all_databases.sql
登录后复制

4. 恢复特定数据库(从全库备份中)

若只想从中提取并恢复某个库,可先用文本处理提取相关SQL段,或使用如下命令筛选:

grep "^-- Current Database: \`mydb\`" all_databases.sql
登录后复制

再配合sedawk提取对应内容导入。

三、提高备份效率与安全性的建议

实际运维中,需考虑自动化、压缩与安全。

1. 压缩备份文件

减少存储空间占用:

mysqldump -u root -p mydb | gzip > mydb_$(date +%Y%m%d).sql.gz
登录后复制

2. 解压并恢复压缩备份

gunzip < mydb_20250405.sql.gz | mysql -u root -p mydb
登录后复制

3. 定时自动备份(使用crontab)

编辑定时任务:

crontab -e
登录后复制

添加每日凌晨1点备份:

0 1 * * * /usr/bin/mysqldump -u root -p密码 mydb | gzip > /backup/mydb_$(date +\%Y\%m\%d).sql.gz
登录后复制

注意:密码直接写在命令行有安全风险,建议使用~/.my.cnf配置文件保存凭据。

4. 使用配置文件避免明文密码

创建~/.my.cnf

[client]
user=root
password=your_password
登录后复制

设置权限防止泄露:

chmod 600 ~/.my.cnf
登录后复制

之后执行mysqldump无需加-u-p

四、常见问题与注意事项

1. 权限不足
确保运行mysqldump的用户具有SELECTSHOW VIEWLOCK TABLES等权限。

2. 大数据库导出慢或超时
可添加参数优化:

--single-transaction   # 适用于InnoDB,避免锁表
--quick                # 逐行读取,减少内存占用
--lock-tables=false    # 避免锁表(多表时谨慎使用)
登录后复制

3. 恢复时出现乱码
确保备份和恢复时字符集一致,可在导出和导入时指定:

--default-character-set=utf8mb4
登录后复制

基本上就这些。掌握mysqldump的基本用法和优化技巧,能有效保障Linux下MySQL数据的安全性与可恢复性。

以上就是Linux如何备份与恢复数据库_Linuxmysqldump备份恢复指南的详细内容,更多请关注php中文网其它相关文章!

数据恢复工具app
数据恢复工具app

手机里的数据丢失了怎么办?聊天记录不小心删掉了怎么办?不用担心,这里为大家提供了数据恢复工具app下载,安全正规,有需要的小伙伴保存下载,就轻松恢复数据啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

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