卷就是目录或文件,存在于一个或多个容器中,由Docker挂载到容器,但不属于联合文件系统,因此能够绕过UFS提供一些用于持久存储或共享数据的特性。卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷。3.
特点:
1.数据卷可在容器之间共享或重用数据;
2.卷中的更改可以直接生效;
3.数据卷中的更改不会包含在镜像的更新中;
4.数据卷的生命周期一直持续到没有容器使用它为止。
一、添加数据卷
1.直接添加
docker run -it -v /宿主机绝对路径目录:/容器内目录 [--privileged=true] 镜像名
容器停止退出后,主机修改卷内文件数据可同步
2.带权限
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
权限:ro.容器只读券,rw.容器读写券
二、DockerFile添加数据卷
案例:
1.根目录下新建mydocker文件夹并进入
2.在Dockerfile中使用命令给镜像添加一个或多个数据卷
3.File构建(Dockerfile脚本)
vim Dockerfile
#volume test
FROM centos
VOLUME ["/dataVolumeContainer1", "/dataVolumeContainer2"]
CMD echo "finished,------success1"
CMD /bin/bash
4.build后生成镜像
# docker build -f /宿主机绝对路径目录 -t 命名空间/镜像名称 .
docker build -f /mydocker/Dockerfile -t test/centos .
5.run容器
docker run -it test/centos
容器内根目录下出现dataVolumeContainer1和dataVolumeContainer2两个数据卷;宿主机上数据卷绝对路径可通过docker inspect 容器id查看。
Docker挂载主机目录Docker访问出现cannot open directory.:Permission denied,解决方法:
在挂载目录后面多加一个--privileged=true
三、数据卷容器
容器间传递共享(--volumes-from)
案例:
1.先启动一个父容器dc01(在dataVolumeContainer2新增内容)
docker run -it --name dc01 test/centos
cd /dataVolumeContainer2/
touch dc01_add.txt
2.dc02/dc03继承自dc01
docker run -it --name dc02 --volumes-from dc01 test/centos
cd /dataVolumeContainer2
touch dc02_add.txt
docker run -it --name dc03 --volumes-from dc01 test/centos
cd /dataVolumeContainer2
touch dc03_add.txt
3.回到dc01可以看到02/03各自添加的都能共享
4.删除dc01,dc02修改后,dc03可否访问
docker rm -f dc01
docker attach dc02
cd /dataVolumeContainer2/
touch dc02_update.txt
5.删除dc02后dc03能否访问
docker rm -f dc02
6.新建dc04继承dc03后再删除dc03
docker run -it --name dc04 --volumes-from dc03 test/centos
docker rm -f dc03
总结:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止。