Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。
为了能保存数据在docker中我们使用容器数据卷
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Uniin File System提供一些用于持续存储或共享数据的特性:
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
数据卷可在容器之间共享或重用数据卷中的更改可以直接生效数据卷中的更改不会包含在镜像的更新中数据卷的生命周期一直持续到没有容器使用它位置docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名
docker run -it -v /myDataVolume:/dataVolumeContainer centos
可以在宿主机的myDataVolume目录和生成的容器的dataVolumeContainer目录里创建文件,并读写文件。 可以看到俩目录里的文件和数据是同步共享的。
测试步骤 1: exit 停止运行中的容器 2: 修改主机目录myDataVolume下的文件内容 3: 启动关闭的容器 4: 查看容器dataVolumeContainer目录下的文件内容 5: 结果已同步
docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名
ro参数:只读(readonly)
当要在容器的数据卷目录里创建文件,会报错误,无法创建文件。 只能操作主机上的目录
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"] 说明: 出于可移植性和分享的考虑,用-v主机目录:容器目录这种方法不能够直接在Dockerfile中实现。 由于宿主机目录是依赖于特定宿主机的,并不能够保证所有的宿主机上都存在这样的特定目录。
等同于 docker run -it -v /主机目录1:/dataVolumeContainer1 -v /主机目录2:/dataVolumeContainer2 centos /bin/bash
docker build -f {dockerfile} -t 要创建的目标镜像名:[标签名] .
docker build -f /myDocker/Dockerfile -t ppjj/centos .Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied 解决办法: 在挂载目录后多追加一个 --privileged=true即可
