docker 数据管理

ops/2024/11/13 15:25:53/

1. 数据管理

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

2. 数据管理命令

2.1 数据卷命令列表
  • docker run --help | grep volume 显示数据卷相关命令。
2.2 数据卷操作
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容器查看

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


http://www.ppmy.cn/ops/113674.html

相关文章

设计模式七大原则

设计模式的七大原则是指导软件设计和架构的基本准则,帮助开发者创建更灵活、可维护和可扩展的系统。以下是这七大原则的详细介绍: 1. 单一职责原则 (SRP: Single Responsibility Principle) 定义 一个类,应当只有一个引起它变化的原因&…

数据结构(Day14)

一、学习内容 结构体 概念 引入:定义整数赋值为10 int a10; 定义小数赋值为3.14 float b3.14; 定义5个整数并赋值 int arr[5] {1 , 2 , 3 , 4 ,5}; 定义一个学生并赋值学号姓名成绩 定义一个雪糕并赋值名称产地单价 问题:没有学生、雪糕 数据类型 解决&…

Docker笔记-Docker Dockerfile

Docker笔记-Docker Dockerfile Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。 这里讲解如何运行 Dockerfile 文件来定制一个镜像。 DockerFile构建过程解析: 1、每条保留字指令都必须为大写字母且后面要…

Python类及元类的创建流程

Python类及元类的创建流程 代码运行结果再看type和object的关系和约定type和object具有的方法不一样看代码和运行结果,可以完全理解python的执行过程。再补充几点, 代码 class MetaCls(type):print(0>>>, MetaCls, 0)def __init__(self, name,…

Langchain-chatchat源码部署及测试实验

一年多前接触到Langchain-chatchat的0.2版本,对0.2版本进行了本地部署和大量更新,但0.2版本对最新的大模型支持不够好,部署框架支持也不好且不太稳定,特别是多模态大模型,因此本次主要介绍0.3版本的源码部署,希望对大家有所帮助。Langchain-chatchat从0.3版本开始,支持更…

射击靶标检测系统源码分享

射击靶标检测检测系统源码分享 [一条龙教学YOLOV8标注好的数据集一键训练_70全套改进创新点发刊_Web前端展示] 1.研究背景与意义 项目参考AAAI Association for the Advancement of Artificial Intelligence 项目来源AACV Association for the Advancement of Computer Vis…

主流卷积神经网络CNN总结

ResNet(2015)残差神经网络 残差结构 ResNet50具体卷积结构图 ResNeXt(2016)加入了分组卷积的思想,将原ResNet网络中的block替换成由group分组的block,两者得到的feature map一致,只是参数量更少…

【数据结构】排序算法---基数排序

文章目录 1. 定义2. 算法步骤2.1 MSD基数排序2.2 LSD基数排序 3. LSD 基数排序动图演示4. 性质5. 算法分析6. 代码实现C语言PythonJavaCGo 结语 ⚠本节要介绍的不是计数排序 1. 定义 基数排序(英语:Radix sort)是一种非比较型的排序算法&…