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容器查看

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

相关推荐
川石课堂软件测试13 分钟前
性能测试|docker容器下搭建JMeter+Grafana+Influxdb监控可视化平台
运维·javascript·深度学习·jmeter·docker·容器·grafana
昌sit!6 小时前
K8S node节点没有相应的pod镜像运行故障处理办法
云原生·容器·kubernetes
追风林7 小时前
mac 本地docker-mysql主从复制部署
mysql·macos·docker
A ?Charis9 小时前
Gitlab-runner running on Kubernetes - hostAliases
容器·kubernetes·gitlab
城南vision9 小时前
Docker学习—Docker核心概念总结
java·学习·docker
wclass-zhengge9 小时前
Docker篇(Docker Compose)
运维·docker·容器
北漂IT民工_程序员_ZG10 小时前
k8s集群安装(minikube)
云原生·容器·kubernetes
梦魇梦狸º13 小时前
腾讯轻量云服务器docker拉取不到镜像的问题:拉取超时
docker·容器·github
鬼才血脉13 小时前
docker+mysql配置
mysql·adb·docker
詹姆斯爱研究Java14 小时前
Docker 的基本概念和优势
docker