本篇来自于尚硅谷周阳老师 https://www.bilibili.com/vide...
上一篇:docker 入门到实战(四)docker镜像

五:docker容器数据卷

5.1 docker容器数据卷是什么

数据卷就是数据(一个文件或者文件夹)。数据卷是特殊的目录,可以绕过联合文件系统,为一个或多个容器提供访问。

数据卷设计的目的是数据的永久化,是完全独立于容器的生命周期,不会在容器删除时删除其挂载的数据卷,也不会存在类似垃圾收集机制,对容器引用的数据卷进行处理。

Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,
那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。

作用:
能让容器持久化
容器之间可以继承和共享数据

5.2 数据卷的特点

  1. 数据卷可在容器之间共享或重用数据
  2. 卷中的更改可以直接生效
  3. 数据卷中的更改不会包含在镜像的更新中
  4. 数据卷的生命周期一直持续到没有容器使用它为止

5.3 添加数据卷(数据目录挂载)==>命令添加

5.3.1 命令添加
 docker run -di -v /宿主机绝对路径目录:/容器内目录 centos

image.png

5.3.2 查看数据是否挂载成功

查看容器内部详情

docker inspect 容器ID

image.png

5.3.3 容器和宿主机之间数据共享

宿主机
image.png

image.png
容器内
image.png
访问网页
image.png

5.3.4 容器停止退出后,主机修改后数据是否同步

宿主机停止容器修改index.html再启动
image.png
进入容器内查看能同步
image.png

5.3.5 目录挂载只读(Read-only)权限
docker run -id -v /宿主机绝对路径目录:/容器内目录:ro 镜像名

5.4 添加数据卷(数据目录挂载)==>DockerFile添加

5.4.1 file构建

dockerfile下章会详解

image.png

FROM centos
VOLUME ["VolumeContainer1","VolumeContainer2"]
CMD echo "finished,---successfully"
CMD /bin/bash

Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied

解决办法:在挂载目录后多加一个--privileged=true参数即可

5.4.2 build后生成镜像

image.png

5.4.3 run 生成容器

image.png

5.4.4 查看目录挂载

image.png

宿主机上
image.png

容器内
image.png

5.5 数据卷容器

命名的容器挂载数据卷,其它容器通过挂载这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器

5.5.1 创建一个父容器

image.png

5.5.2 在父容器中添加数据

image.png

5.5.3 创建两个子容器继承父容器
docker run -it --name 子容器 --volumes-from 父容器 image

两个son容器都有father.txt 实现了数据共享
image.png

image.png

5.5.4 验证信息传递

删除父容器
image.png

在子容器1中新增数据
image.png

查看子容器2中的数据
image.png

新增孙容器grandson 继承子容器1
image.png

删除子容器1
image.png

在孙容器中新增数据
image.png

查看子容器2中的数据
image.png

结论:容器之间数据的传递,数据卷的什么周期一直持续到没有容器使用它为止

下一篇:
docker 入门到实战(六)dockerFile解析


Remember
24 声望3 粉丝

蓝色空间号里的blueBoy