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

news/2025/2/26 20:58:37

文章目录

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.niftyadmin.cn/n/5869166.html

相关文章

Docker 搭建 Nginx 服务器

系列文章目录 Docker 搭建 Nginx 服务器 系列文章目录前言一、准备工作二、设置 Nginx 容器的目录结构三、启动一个临时的 Nginx 容器来复制配置文件四、复制 Nginx 配置文件到本地目录五、删除临时 Nginx 容器六、创建并运行 Nginx 容器&#xff0c;挂载本地目录七、修改 ngin…

PyTorch常用函数总结(持续更新)

本文主要记录自己在用 PyTorch复现经典模型 过程中遇到的一些函数及用法&#xff0c;以期对 常见PyTorch函数 更加熟练~ 官方Docs&#xff1a;PyTorch documentation — PyTorch 2.6 documentation 目录 数据层面 torch.sign(tensor) torch.tensor(np.eye(3)[y]) torch.on…

文心一言AI创意画

介绍 文心一言是百度推出的新一代知识增强大语言模型&#xff0c;属于文心大模型家族的新成员。‌它能够与人对话互动、回答问题、协助创作&#xff0c;高效便捷地帮助人们获取信息、知识和灵感。‌ 特点 文心一言基于数万亿数据和数千亿知识进行融合学习&#xff0c;采用预训…

【大语言模型】【整合版】DeepSeek 模型提示词学习笔记(散装的可以看我之前的学习笔记,这里只是归纳与总结了一下思路,内容和之前发的差不多)

以下是个人笔记的正文内容: 原文在FlowUs知识库上&#xff0c;如下截图。里面内容和这里一样&#xff0c;知识排版好看一点 一、什么是 DeepSeek 1. DeepSeek 简介 DeepSeek 是一家专注于通用人工智能&#xff08;AGI&#xff09;的中国科技公司&#xff0c;主攻大模型研发与…

Android Audio实战——音频相关基础概念(附)

Android Audio 开发其实就是媒体源数字化的过程,通过将声波波形信号通过 ADC 转换成计算机支持的二进制的过程叫做音频采样 (Audio Sampling)。采样 (Sampling) 的核心是把连续的模拟信号转换成离散的数字信号。 一、声音的属性 1、响度 (Loudness) 响度是指人类可以感知到的…

IDEA配置Github上传项目

1. 创建项目仓库 2. 设置独立账户 可配置ssh key 可配置令牌&#xff0c;这里选择令牌&#xff0c;Personal access tokens 生成个人访问令牌&#xff1a; 登录到 GitHub&#xff0c;前往 Settings > Developer settings > Personal access tokens&#xff0c;生成一个…

FastAPI高级特性(二):错误处理、中间件与应用生命周期

前言 FastAPI 不仅以其高性能和易用性著称,还内置了丰富的高级特性,使得开发者可以快速组织和封装各种功能。在本篇博客中,我们将深入探讨 FastAPI 的一些高级特性,包括错误处理、中间件和应用生命周期管理。通过这些特性,开发者可以在应用的不同阶段和层面上挂载自定义逻…

机器视觉--线扫相机触发

绪论 在当今蓬勃发展的机器视觉领域&#xff0c;线扫相机堪称关键角色&#xff0c;它凭借高分辨率的扫描成像能力&#xff0c;广泛应用于工业检测、物流识别、印刷质量检测等众多核心场景。线扫相机的触发方式作为成像环节的核心要素&#xff0c;直接决定了图像采集的精准度与…