Docker 核心技术之数据管理
Docker 数据卷简介
为什么用数据卷
- 宿主机无法直接访问容器中的文件
- 容器中的文件没有持久化,导致容器删除后,文件数据也随之消失
- 容器之间也无法直接访问互相的文件
为解决这些问题,docker加入了数据卷(volumes)机制,能很好解决上面问题,以实现:
- 容器与主机之间、容器与容器之间共享文件
- 容器中数据的持久化
- 将容器中的数据备份、迁移、恢复等
数据卷的特点
- 数据卷存在于宿主机的文件系统中,独立于容器,和容器的生命周期是分离的。
- 数据卷可以目录也可以是文件,容器可以利用数据卷与宿主机进行数据共享,实现了容器间的数据共享和交换。
- 容器启动初始化时,如果容器使用的镜像包含了数据,这些数据会拷贝到数据卷中。
- 容器对数据卷的修改是实时进行的。
- 数据卷的变化不会影响镜像的更新。数据卷是独立于联合文件系统,镜像是基于联合文件系统。镜像与数据卷之间不会有相互影响。
Docker 数据卷管理
Docker挂载容器数据卷的三种方式
- bind mounts:将宿主机上的一个文件或目录被挂载到容器上。
- volumes:由Docker创建和管理。使用docker volume命令管理
- tmpfs mounts:tmpfs 是一种基于内存的临时文件系统。tmpfs mounts 数据不会存储在磁盘上。
bind mounts方式挂载数据卷
利用 docker run/create的参数为容器挂载数据卷
方式一: -v, --volume参数
- -v 宿主机文件或文件夹路径:容器中的文件或者文件夹路径
方式二:--mount参数
- --mount type=bind, src=宿主机文件或文件夹路径, dst=容器中的文件或者文件夹路径
注意:src指定的文件和路径必须提前创建或存在
方式一:命令演示
把宿主机上 root 目录下的 volume_dir 绑定到 到容器的c_dir下 (使用 -v 挂载 宿主机上的文件/文件夹不存在的话会自动创建)
docker run -dti -v /root/volume_dir:/root/c_dir centos
在容器内创建一个文件
docker exec ab2 touch /root/c_dir/text.txt
这时在宿主机的 volume_dir 目录下可以查看
方式二:命令演示
把宿主机上 root 目录下的 mount_dir 绑定到 到容器的c_dir2下 (使用 -mount 挂载 宿主机上的文件/文件夹不存在的话会报错)
docker run -dti --mount type=bind,src=/root/mount_dir,dst=/root/c_dir2 centos docker exec 5f7c touch /root/c_dir2/text.txt ls
volumes方式挂载数据卷
利用docker run/create为容器挂载数据卷
方式一: -v, --volume参数
- -v VOLUME-NAME:容器中的文件或者文件夹路径
方式二:--mount 参数
- --mount type=volume, src=VOLUME-NAME, dst=容器中的文件或者文件夹路径
volume对象管理:
- docker volume 命令管理volume数据卷对象
- docker volume create 创建数据卷对象
- docker volume inspect 查看数据卷详细信息
- docker volume ls 查看已创建的数据卷对象
- docker volume prune 删除未被使用的数据卷对象
- docker volume rm 删除一个或多个数据卷对象
查看 docker 中所有的数据卷
docker volume ls
方式一:命令演示 (指定了一个docker 中不存在的数据卷,会自动的创建)
docker run -dti -v volume_test:/root/c_dir centos docker volume ls
方式二:命令演示(指定了一个docker 中不存在的数据卷,会自动的创建)
docker run -dti --mount type=volume,src=volume-test2,dst=/root/c_dir centos
tmpfs mount方式挂载数据卷
利用docker run/create为容器挂载数据卷
- --mount type=tmpfs, dst=PATH
命令演示
docker run -dti --mount type=tmpfs,dst=/root/c_dir centos docker volume ls
共享其他容器的数据卷-数据卷容器
利用docker run/create 的--volumes-from参数指定数据卷容器
- docker run/create --volumes-from CONTAINER
docker run -dti --mount type=volume,src=volume,dst=/root/c_dir centos docker run -dti --volumes-from 5fe centos docker volume ls docker volume inspect volume cd /var/lib/docker/volumes/volume/_data # 在两个容器中创建文件 docker exec 5fe touch /root/c_dir/text.txt docker exec 5fee24 touch /root/c_dir/new_text.txt ls
可以发现他们是共用一个数据卷的
Docker 数据卷注意事项
Docker的数据卷更多会是使用volumes方式来进行使用。使用时需注意:
- 如果挂载一个空的数据卷到容器中的一个非空目录中,那么这个目录下的文件会被复制到数据卷中。
- 如果挂载一个非空的数据卷到容器中的一个目录中(这个目录为空),那么容器中的目录中会显示数据卷中的数据。如果原来容器中的目录中有数据,那么这些原始数据会被隐藏掉(隐藏掉数据卷中的原始数据,只显示容器本身的数据)。
- 这两个规则都非常重要,灵活利用第一个规则可以帮助我们初始化数据卷中的内容。掌握第二个规则可以保证挂载数据卷后的数据总是你期望的结果。
重点掌握
- 数据卷特征和简介
- mount方式绑定数据卷
- 数据卷挂载的三种形式
- 数据卷使用的注意事项
Docker 核心技术之数据管理的更多相关文章
- Docker容器的数据管理
Docker容器的数据管理 Docker容器的数据管理 什么是数据卷(Data Volume)? 数据卷是经过特殊设计的目录,可以绕过联合文件系统(UFS),为一个或者多个容器提供访问 数据卷设计的目 ...
- Docker 核心技术与实现原理
提到虚拟化技术,我们首先想到的一定是 Docker,经过四年的快速发展 Docker 已经成为了很多公司的标配,也不再是一个只能在开发阶段使用的玩具了.作为在生产环境中广泛应用的产品,Docker 有 ...
- Docker核心技术
Docker核心技术 1.cgroup 即controller group,其重要概念是子系统,首先挂载子系统,然后才有control group.例如cpu子系统,挂载至系统之后,创建一个cgrou ...
- Docker学习(14) Docker容器的数据管理
Docker容器的数据管理 Docker容器的数据卷 重要: Docker的数据卷容器 Docker数据卷的备份和还原
- 深入浅出Docker(一):Docker核心技术预览
Docker是PaaS供应商dotCloud开源的一个基于LXC 的高级容器引擎,源代码托管在 GitHub 上, 基于Go语言开发并遵从Apache 2.0协议开源.Docker提供了一种在安全.可 ...
- Docker入门之五数据管理
在Docker使用过程中,需要对数据进行持久化或需要在多个容器之间进行数据共享,就会涉及容器的数据管理操作.主要有两种方式:1.数据卷 2.数据卷容器. 一.数据卷 数据卷是一个可供容器使用的特殊目录 ...
- 后端技术杂谈10:Docker 核心技术与实现原理
本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下 ...
- docker核心技术(2)
鸟瞰容器生态系统 一谈到容器,大家都会想到 Docker. Docker 现在几乎是容器的代名词.确实,是 Docker 将容器技术发扬光大.同时,大家也需要知道围绕 Docker 还有一个生态系统. ...
- 【转】Docker 核心技术与实现原理
转自:https://draveness.me/docker 提到虚拟化技术,我们首先想到的一定是 Docker,经过四年的快速发展 Docker 已经成为了很多公司的标配,也不再是一个只能在开发阶段 ...
随机推荐
- 用ASP.NET Core 2.1 建立规范的 REST API -- HATEOAS
本文所需的一些预备知识可以看这里: http://www.cnblogs.com/cgzl/p/9010978.html 和 http://www.cnblogs.com/cgzl/p/9019314 ...
- Docker 上传镜像
文章首发自个人网站:https://www.exception.site/docker/docker-push-image 本文中,您将学习如何上传 Docker 镜像至 Docker Hub 上. ...
- 深度解密Go语言之Slice
目录 当我们在说 slice 时,到底在说什么 slice 的创建 直接声明 字面量 make 截取 slice 和数组的区别在哪 append 到底做了什么 为什么 nil slice 可以直接 a ...
- 校园生活app结对开发第二天
昨天进行了android studio的安装与配置遇到很多问题,在gradel处遇到很多问题,安装版本错误等等,在百度和书籍的帮助下成功安装 今天要做登陆界面开发
- Dubbo和Spring Cloud微服务架构'
微服务架构是互联网很热门的话题,是互联网技术发展的必然结果.它提倡将单一应用程序划分成一组小的服务,服务之间互相协调.互相配合,为用户提供最终价值.虽然微服务架构没有公认的技术标准和规范或者草案,但业 ...
- 小程序中使用ECharts 异步加载数据
官网例子都是同步的,怎么引入及同步demo请移步官网 <view class="container"> <ec-canvas id="mychart-d ...
- Intel MKL FATAL ERROR: Cannot load mkl_intel_thread.dll
Intel MKL FATAL ERROR: Cannot load mkl_intel_thread.dll 在使用Anaconda创建一个虚拟环境出来,然后安装了scikit-learn.nump ...
- odoo12 物流 自动计算运费 ,采购销售使用不同计量单位自动换算
在物流和食品生鲜类行业,重量是很重要的因素,不仅要处理产品的数量,也要处理产品的重量.在多数行业,重量也是订单的重要数据. odoo原生包含了对重量的处理,下文中将指导如何优雅应用odoo原生模块处理 ...
- PM领导能力成熟度2级
人生如戏,大幕拉开,他走上舞台,饰演PM一角. 从技术岗位迈向管理岗位的第一步,对大多数像他一样的新晋PM来说,并不轻松.技术知识与经验是他曾经的主要才能与成功基础,而从成熟度一级开始,身为管理者的他 ...
- 测者的测试技术手册:测试应该关注java.util.List.subList的坑
java中有一个返回子列表的方法: public list<E> subList(int fromIndex, int toIndex){ subListRangeCheck( ...