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

五:docker容器数据卷

5.1 docker容器数据卷是什么

数据卷就是数据(一个文件或者文件夹)。数据卷是特殊的目录,可以绕过联合文件系统,为一个或多个容器提供访问。
数据卷设计的目的是数据的永久化,是完全独立于容器的生命周期,不会在容器删除时删除其挂载的数据卷,也不会存在类似垃圾收集机制,对容器引用的数据卷进行处理。
Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,
那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。

作用:

  1. 能让容器持久化
  2. 容器之间可以继承和共享数据

    5.2 数据卷的特点

  3. 数据卷可在容器之间共享或重用数据

  4. 卷中的更改可以直接生效
  5. 数据卷中的更改不会包含在镜像的更新中
  6. 数据卷的生命周期一直持续到没有容器使用它为止

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

    5.3.1 命令添加

    1. docker run -di -v /宿主机绝对路径目录:/容器内目录 centos
    1.png

5.3.2 查看数据是否挂载成功

查看容器内部详情

  1. docker inspect 容器ID

2.png

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

宿主机
3.png
4.png
容器内
5.png
访问网页
6.png

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


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

5.3.5 目录挂载只读(Read-only)权限

  1. docker run -id -v /宿主机绝对路径目录:/容器内目录:ro 镜像名

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

5.4.1 file构建

dockerfile下章会详解
9.png

  1. FROM centos
  2. VOLUME ["VolumeContainer1","VolumeContainer2"]
  3. CMD echo "finished,---successfully"
  4. CMD /bin/bash

Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied
解决办法:在挂载目录后多加一个—privileged=true参数即可

5.4.2 build后生成镜像

10.png

5.4.3 run 生成容器

1.png

5.4.4 查看目录挂载

2.png
宿主机上
3.png
容器内
4.png

5.5 数据卷容器

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

5.5.1 创建一个父容器

5.png

5.5.2 在父容器中添加数据

6.png

5.5.3 创建两个子容器继承父容器

  1. docker run -it --name 子容器 --volumes-from 父容器 image


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

5.5.4 验证信息传递

删除父容器
8.png
在子容器1中新增数据
9.png
查看子容器2中的数据
10.png
新增孙容器grandson 继承子容器1
11.png
删除子容器1
12.png
在孙容器中新增数据
13.png
查看子容器2中的数据
14.png
结论:容器之间数据的传递,数据卷的使用周期一直持续到没有容器使用它为止

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