对Docker部署的MySQL中的数据进行备份恢复

文章目录

[1. 启动MySQL容器](#1. 启动MySQL容器)

[2. 使用 docker exec 运行 mysqldump](#2. 使用 docker exec 运行 mysqldump)

[2.1 备份单个数据库](#2.1 备份单个数据库)

[2.2 备份所有数据库](#2.2 备份所有数据库)

[3. 压缩备份文件](#3. 压缩备份文件)

[3.1 压缩备份单个数据库](#3.1 压缩备份单个数据库)

[3.2 压缩备份所有数据库](#3.2 压缩备份所有数据库)

[4. 自动化备份](#4. 自动化备份)

[4.1 编辑 crontab 文件](#4.1 编辑 crontab 文件)

[4.2 添加备份任务](#4.2 添加备份任务)

[5. 恢复备份](#5. 恢复备份)

[5.1 恢复单个数据库](#5.1 恢复单个数据库)

[5.2 恢复所有数据库](#5.2 恢复所有数据库)

[5.3 恢复压缩备份](#5.3 恢复压缩备份)

[6. 注意事项](#6. 注意事项)


使用Docker部署的MySQL进行备份/恢复与传统方式类似,但需要考虑Docker容器的特殊性。以下是详细的步骤,帮助你在Docker环境中进行MySQL的全量备份。

1. 启动MySQL容器

假设你已经有一个运行中的MySQL容器,可以通过以下命令获取容器ID或名称:

复制代码
docker ps
2. 使用 docker exec 运行 mysqldump

docker exec 命令允许你在运行中的容器内执行命令。以下是一个示例,备份名为 mydatabase 的数据库:

2.1 备份单个数据库
复制代码
docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p<password> mydatabase' > mydatabase_backup.sql

参数说明:

  • <container_name_or_id>: 替换为你的MySQL容器的名称或ID。
  • -u root -p: 替换为你的MySQL用户名和密码。
  • mydatabase: 要备份的数据库名称。
  • > mydatabase_backup.sql: 将备份内容输出到本地文件中。
2.2 备份所有数据库
复制代码
docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p<password> --all-databases' > all_databases_backup.sql
3. 压缩备份文件

为了节省磁盘空间,可以在备份过程中直接压缩输出文件:

3.1 压缩备份单个数据库
复制代码
docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p<password> mydatabase' | gzip > mydatabase_backup.sql.gz
3.2 压缩备份所有数据库
复制代码
docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p<password> --all-databases' | gzip > all_databases_backup.sql.gz
4. 自动化备份

为了定期自动备份数据库,可以使用 cron 任务。以下是一个示例 crontab 条目,每天凌晨1点备份 mydatabase 并压缩:

4.1 编辑 crontab 文件
复制代码
crontab -e
4.2 添加备份任务
复制代码
0 1 * * * docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p<password> mydatabase' | gzip > /path/to/backup/mydatabase_$(date +%Y%m%d).sql.gz

参数说明:

  • 0 1 * * *: 每天凌晨1点执行。
  • docker exec -i <container_name_or_id> sh -c 'exec mysqldump -u root -p mydatabase': 在指定的MySQL容器中备份 mydatabase。
  • | gzip: 压缩备份文件。
  • > /path/to/backup/mydatabase_$(date +%Y%m%d).sql.gz: 将备份文件保存到指定路径,并使用日期命名。
5. 恢复备份

恢复备份时,可以使用 mysql 命令将备份文件导入到数据库中。

5.1 恢复单个数据库
复制代码
docker exec -i <container_name_or_id> mysql -u root -p<password> mydatabase < mydatabase_backup.sql
5.2 恢复所有数据库
复制代码
docker exec -i <container_name_or_id> mysql -u root -p<password> < all_databases_backup.sql
5.3 恢复压缩备份

如果备份文件是压缩的,需要先解压再恢复:

复制代码
gunzip < mydatabase_backup.sql.gz | docker exec -i <container_name_or_id> mysql -u root -p<password> mydatabase
6. 注意事项
  • 权限: 确保备份用户有足够的权限访问所有需要备份的数据库和表。
  • 性能: 大型数据库备份可能会对服务器性能产生影响,建议在低峰时段进行备份。
  • 安全性: 不要在脚本中明文存储密码,可以使用配置文件或环境变量来管理密码。
  • 容器状态: 确保MySQL容器在备份时是运行状态。

通过以上步骤,你可以在Docker环境中有效地进行MySQL的备份和恢复。

相关推荐
菜鸟笔记本12 小时前
linux设置定时备份mysql数据
linux·mysql·oracle
千寻技术帮12 小时前
10347_基于Springboot的新疆旅游管理系统
spring boot·mysql·旅游·在线旅游
Web项目开发14 小时前
Mysql创建索引的SQL脚本,复制粘贴即可使用
数据库·sql·mysql
2501_9399090514 小时前
k8s基础与安装部署
云原生·容器·kubernetes
主公不搬砖14 小时前
Nacos 2.5.2 国产信创 kingbase适配
java·docker·nacos·信创·kingbase·国产适配
小罗和阿泽15 小时前
MySql数据库系列 数据库基础操作
数据库·mysql
周末吃鱼15 小时前
mysql8.0支持CURRENT_DATE如何写
数据库·sql·mysql
谷隐凡二15 小时前
Kubernetes Route控制器简单介绍
java·容器·kubernetes
kaico201815 小时前
MySQL的窗口函数
数据库·mysql
薛定谔的猫198215 小时前
LlamaIndex(三) LlamaHub工具集
数据库·mysql·llamahub