docker 数据管理

1. 数据管理

1.1 什么是数据管理
  • docker的镜像是只读的。
  • 容器可以进行操作,但数据不能保存到容器中。
  • 数据保存需要使用数据卷和数据卷容器。
1.2 容器、数据卷、数据卷容器关系图
1.2.1 什么是数据卷
  • 宿主机的某个目录映射到容器中,作为数据存储的目录。
1.2.2 什么是数据卷容器
  • 宿主机的某个目录使用容器的方式来表示。
  • 其他应用容器将数据保存在这个容器中。
  • 达到大批量应用数据同时存储的目的。

2. 数据管理命令

2.1 数据卷命令列表
  • docker run --help | grep volume 显示数据卷相关命令。
2.2 数据卷操作
  • docker run -itd --name [容器名字] -v [宿主机文件]:[容器文件] [镜像名称]
2.3 数据卷容器操作
  1. 创建数据卷容器
    • docker create -v [宿主机文件]:[容器数据卷目录] --name [容器名字] [镜像名称] [命令(可选)]
  2. 使用数据卷容器
    • docker run --volumes-from [数据卷容器名字] -d --name [容器名字] [镜像名称] [命令(可选)]

3. 数据卷、数据卷容器实战

3.1 数据卷实战
3.1.1 挂载目录的测试
  • 创建测试文件 echo "file1" >/tmp/test.txt
  • 启动nginx容器并且挂载硬盘 docker run -tid --name test1 -v /tmp:/test1 nginx
  • 进入容器查看文件是否存在
3.1.2 挂载文件的测试
  • 创建测试文件 echo "file" > /tmp/test.txt
  • 启动nginx容器并且挂载硬盘 docker run -itd --name test2 -v /tmp/test.txt:/test/file/test.sh nginx
  • 进入容器查看文件是否存在
3.2 数据卷容器实战
3.2.1 创建数据卷
  • 创建宿主机的目录 mkdir /data
  • 创建vol-test容器 docker create -v /data:/data --name vol-test nginx
3.2.2 挂载数据卷
  • 挂载数据卷 docker run --volumes-from vol-test -d --rm --name vc-test1 nginx
  • 挂载数据卷 docker run --volumes-from vol-test -d --rm --name vc-test2 nginx
3.2.3 确认效果
  • 进入vc-test1,操作数据卷容器
  • 进入vc-test2,确认数据卷
  • 回到宿主机查看/data/目录

4. 备份还原

4.1 基础知识
4.1.1 需求
  • 基于数据卷和数据卷容器知识,实现容器应用内部的数据备份还原实践。
4.1.3 数据备份方案
  1. 创建一个挂载数据卷容器的容器。
  2. 挂载宿主机本地目录作为备份数据卷。
  3. 将数据卷容器的内容备份到宿主机本地目录挂载的数据卷中。
  4. 完成备份操作后销毁刚创建的容器以及关联的容器卷。
4.1.4 数据恢复方案
  1. 创建一个新的数据卷容器。
  2. 创建一个新容器,挂载数据卷容器,同时挂载本地的备份目录作为数据卷。
  3. 将要恢复的数据解压到容器中。
  4. 完成还原操作后销毁刚创建的容器以及关联的容器卷。
4.2 备份实践
4.2.1 查看原来的数据卷容器
  • 原来创建,参考小节创建:3.2.1、创建数据卷
4.2.2 备份操作
  • 创建备份的目录 mkdir /backup
  • 创建备份的容器,并且挂载/backup,然后执行备份压缩至/data
    • docker run --rm --volumes-from vol-test -v /backup:/backup nginx tar zcf /backup/data.tar.gz /data
  • 验证操作
4.3 还原实践
4.3.1 删除vc-test1的数据
  • 删除vc-test1的数据
4.3.2 还原
  • 恢复数据
    • docker run --rm --volumes-from vol-test -v /backup:/backup nginx tar xf /backup/data.tar.gz -C /
  • vc-test1容器查看

这种结构清晰地展示了文档的主要内容,包括数据管理的概念、命令、实战操作以及备份还原的基础知识和实践步骤。

相关推荐
Dillon Dong1 小时前
【系统运维】Docker版本冲突问题详解:从错误到解决方案
docker·容器
Dillon Dong1 小时前
【系列主题】从 Docker 构建失败看依赖隔离:多阶段构建的“隐形陷阱”
运维·docker·容器
AI服务老曹2 小时前
从底层协议对接说起:基于 GB28181/RTSP 的异构视频流接入架构设计与源码级解析
人工智能·docker
如果'\'真能转义说3 小时前
《数据不丢失!本地挂载的 Docker 一键启动PS1脚本》
运维·docker·容器
郝开3 小时前
Docker Compose 本地环境搭建:mysql
mysql·docker·容器
Dillon Dong3 小时前
【系列主题】拯救 OOM 与构建中断:Next.js 在 Docker 中的静态生成(SSG)避坑指南
开发语言·javascript·docker
阿桂有点桂3 小时前
Laravel队列再docker中开启和配置
docker·php·laravel
人工智能培训4 小时前
AI模型部署进阶:Docker容器化部署AI项目
人工智能·深度学习·机器学习·docker·容器·transformer·知识图谱
胡小禾4 小时前
K8S Helm
docker·容器·kubernetes
SPC的存折4 小时前
1、K8S-单Master集群部署-OpenEuler24.03
云原生·容器·kubernetes