当前位置: 首页 > news >正文

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

文章目录

1. 启动MySQL容器

2. 使用 docker exec 运行 mysqldump

2.1 备份单个数据库

2.2 备份所有数据库

3. 压缩备份文件

3.1 压缩备份单个数据库

3.2 压缩备份所有数据库

4. 自动化备份

4.1 编辑 crontab 文件

4.2 添加备份任务

5. 恢复备份

5.1 恢复单个数据库

5.2 恢复所有数据库

5.3 恢复压缩备份

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的备份和恢复。

http://www.dtcms.com/a/609736.html

相关文章:

  • AI 时代企业新形态:超级个体与多智能体
  • 夜场酒吧娱乐ktv类企业网站源码网上花店网页制作素材
  • wordpress 微博链接地址南京百度网站快速优化
  • 新操作系统
  • 电商网站html模板介绍公司的简介范文
  • 卡索(CASO)汽车调查:数据智能时代,汽车产业竞争格局与战略升维路径探析
  • 新能源汽车电源环路设计:从PID补偿到数字化控制的落地实践
  • BERT 完整教程指南
  • 陆丰网站宁波微网站建设
  • 如何利用技术手段来甄选一套档案馆库房安全温湿度监控系统
  • undefined symbol: _ZN3c104cuda9SetDeviceEab
  • 工业 4.0 微观基石:整列机赋能精密零件整列,筑牢无人工厂根基
  • EG1164 DC-DC升压型同步整流电源芯片技术解析
  • 【Spring Cloud 整合Nacos和Seata实现分布式事务】
  • LeetCode hot100:4.寻找两个正序数组的中位数 题解分析
  • 邦邻营销型网站建设运城建设银行网站
  • docker(25) : 银河麒麟 V10离线安装docker
  • mysql 网站空间壹淘购返利网
  • 小鹏VLA 2.0的“神秘涌现”:从痛苦到突破,自动驾驶与机器人如何突然“开窍”?
  • 第五章《Android 数据存储》
  • Axios 与 HTTP 状态码:构建健壮前端请求体系的完整指南
  • acos支持mcp,内置mcp server支持让注册到r-nacos的普通http接口通过r-nacos直接转化成mcp服务对外提供服务。
  • HTTP头信息相关知识了解
  • 做淘客app要网站吗建设工程师交易网站
  • 泛型擦除与桥接方法
  • 深度相机kinect拍摄的.mkv深度视频为什么特别大,mkv文件中含有什么数据,以及数据格式是什么
  • 带数据库网站设计金桥网站建设
  • 国内网站如何做流量网络营销怎么做有特色
  • ios卡顿优化
  • 4G/5G参考信号详解