Docker容器数据卷
是什么?
Docker容器产生的数据,如果不通过docker commit 生成新的镜像,使得数据做为镜像的一部分保存下来。
那么当容器删除后,数据自然就没 有了
为了能保存数据在docker中我们使用卷
一句话: 有点类似我们Redis 里面的rdb和aof文件
能干嘛?
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
-
数据卷可在容器之间共享或重用数据454
-
卷中的更改可以直接生效
-
数据卷中的更改不会包含在镜像的更新中
-
数据卷的声明周期一直持续到没有容器使用它为止
数据卷
容器中添加数据卷的两种方式:
-
直接命令添加
命令:docker run - it -v/宿主机绝对路径目录:/容器内目录 镜像名
例:
docker run -it -v /myDataVolume:/dataVolumeContainer centos
-
命令(带读写权限)
docker run -it -v /myDataVolume:/dataVolumeContainer:ro centos #代表容器内对文件只能读,不可以写
-
DockerFile添加
-
在根目录下新建mydocker 文件夹并进入
-
然后新建file文件
# volume test FROM centos VOLUME ["/dataVolumeContainer1", "/dataVolumeContainer2"] CMD echo "finished,------success1" CMD /bin/bash
-
build 后生成镜像
sudo docker build -f /mydocker/file -t zd/centos .
-
run容器
docker run -it zd/centos /bin/bash
-
数据卷容器
是什么?
命名的容器挂载数据卷,其它容器通过挂载这个父容器实现数据共享,挂载数据卷的容器,称之为数据卷容器