说明
卷就是目录或文件,存在于一个或多个容器中,由于docker 挂载到容器,但不属于联合文件系统,因此能够绕过UnionFile System 提供一些用于持续存储或共享数据的特性。
卷的设计的目的就是数据的持久化,完全独立于容器的生命周期,因此Docker不会在容器删除时删除其挂载的数据卷。
功能
实现容器的持久化、容器间的继承和共享数据
特点
1、数据卷可以在容器之间共享或重用数据
2、卷中的更改可以直接生效
3、数据卷中的更改不会包含在镜像的更新中
4、数据卷的生命周期一直持续到没有容器使用它为止。
使用
直接命令添加
命令:
docker run -it -v/宿主机绝对路径目录:/容器内目录 镜像名
容器内只读
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
注意:Docker 挂载目录Docker 访问出现cannot open directory.:Permission denied
解决办法:在挂载目录后面多加一个–privileged=true 参数即可
例子: docker run -it -v /zxx:/zxxc centos --privileged=true
DockerFile添加
DockerFile 相当于镜像的源文件
新建文件夹并进入
新建DockerFile 使用VOLUME 指令来给镜像添加一个或多个数据卷
File构建
build后生成镜像
例子 docker build -it /zxx/Dockerfile -t zxx/centos .
注意命令后面的 .
run容器
数据卷容器
命名的容器挂载数据卷,其他容器通过这个(父容器)实现数据共享,挂载数据卷的容器,称之为数据卷容器。
先启动一个父容器 c01
例子: docker run -it --name c01 zxx/centos
c02/c03继承自父容器
例子:docker run -it --name c02 --volumes-from zxx/centos
回到c01可以看到c02/c03 各自添加的都能共享
删除c01后,c02/c03都可以访问
新建c04继承c03后在删除c03 ,c04还是可以访问。
结论:容器之间的配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止。