是什么
docker容器产生的数据,如果不通过commit生成新的镜像,使得数据作为镜像的一部分保存下来,那么当容器删除后,数据就没有了。
为了能保存数据,在docker中使用卷。
类似于redis中的rdb和aof文件。
能干嘛
数据卷就是目录或文件,存在一个或多个容器中,由docker挂载到容器,但不属于联合文件系统。
卷的设计目的就是数据持久化,完全独立于容器的生存周期,不会在容器删除时删除挂载的数据卷。
特点:
可以在容器之间共享或重用数据
卷中的修改可以直接生效
数据卷的更改不会包含在镜像的更新中
数据卷的生命周期一直持续到没有容器使用它为止。
数据卷
容器内添加
直接命令添加
docker run -it -v /主机绝对路径目录:/容器内目录 镜像名
查看是否挂载成功 docker inspect container 查看Binds信息
容器和宿主机之间数据共享,实时共享
容器停止退出后,主句修改后的数据是否同步,是的
命令docker run -it -v /主机绝对路径目录:/容器内目录:ro 镜像名 容器只读,只能在主机写文件。
DockerFile添加
创建DockerFile 文件 /mydocker/DockerFile
FROM centos
VOLUME [ “/dataVolumeContainer1” , “/dataVolumeContainer2”]
CMD echo “finished----”
CMD [“/usr/sbin/init”]
执行命令,创建镜像
docker build -f /mydocker/DockerFile -t hukl/centos .
根据镜像创建容器,此时容器的数据卷对应的主机目录是docker默认分配的。
docker run -it dc01 hukl/centos
Docker挂载主机目录Docker访问出现cannot open directory.:Permission denied,解决办法在挂载目录后多加一个–priviledge=true
数据卷容器
上一步构建的容器中有2个数据卷
再创建两个容器dc02和dc03继承自dc01
docker run -it --name dc02 --volumes-from dc01 hukl/centos
docker run -it --name dc03 --volumes-from dc01 hukl/centos
即使删除dc01数据文件仍然会保存,并共享。数据卷的生命周期一直持续到没有容器使用它为止。