目录
1.什么是数据卷
2.如何添加数据卷
2.1命令方式
2.2Dockerfile方式
3.使用数据卷
3.1Docker与宿主机数据共享
3.2Docker间数据卷共享
1.什么是数据卷
Docker数据卷类似虚拟机的共享文件夹。
- 数据卷作用
①用于容器数据持久化;
②容器间数据共享。
其中容器数据持久化不是说容器停止运行,数据还保存,而是容器删除,数据依然保存。Docker产生的数据,如果不通过docker commit生成新的镜像,使数据成为镜像的一部分保存下来,那么容器删除后,数据自然也就没了(容器stop后再重启,数据还是会保留的)。
2.如何添加数据卷
2.1命令方式
第一步:执行docker run -v命令,创建容器时绑定数据卷
docker run –it –v /宿主机绝对路径:/容器内目录[:ro] [--privileged=true] 镜像名
-v:volume,绑定数据卷
ro:read only,容器内此目录只读
--privileged=true:使用该参数,容器内的root拥有真正的root权限,如果遇到权限问题不能写数据卷文件夹,使用此参数
以上命令将容器内的/dockerdata目录映射到宿主机的/dockerdata。
第二步:执行docker inspect命令,查看是否绑定数据卷成功
以上可以看到,数据卷绑定成功。
2.2Dockerfile方式
第一步:编写Dockerfile
vim Dockerfile
从docker hub上拉取centos
FROM centos
容器内创建/dockerdata1和/dockerdata2两个数据卷
VOLUME [“/dockerdata1”,”/dockerdata2”]
打印success
CMD echo “success.”
CMD /bin/bash
说明:出于移植和分享考虑,用-v 主机目录方法不能直接在Dockerfile实现(因为宿主机中可能没有这个文件夹),VOLUME只能设置docker容器内的数据卷,宿主机会默认提供目录与之对应,可通过docker inspect命令查看。
第二步:执行docker build,生成镜像
docker build命令用于根据给定的Dockerfile和上下文以构建Docker镜像。
docker build [参数] [PATH | URL | -]
参数说明:
-f:指定使用的Dockerfile;
-t:创建镜像的名字及tag;
[PATH | URL | -]:Dockerfile所在路径,可以是Dockerfile所在的本地路径PATH,也可以是远程URL,如Git库、tarball或文本文件等,还可以是-,表示通过STDIN给出Dockerfile。
以上通过docker build生成houpk/centos镜像,默认TAG为latest。
第三步:执行docker run,创建容器
执行如下命令
docker run -it 镜像 /bin/bash
第四步:执行docker inspect,查看数据卷挂载情况
3.使用数据卷
3.1Docker与宿主机数据共享
在宿主机数据卷目录下创建或修改文件,在容器内可以看到。
Docker容器停止运行,在宿主机文件夹下做修改,docker容器再启动后,可以看到修改。
3.2Docker间数据卷共享
在执行docker run创建容器时,使用--valume-from参数,表示新容器继承指定容器的数据卷。
docker run -it --name dc01 --volumes-from dc00 镜像
表示按镜像创建名字为dc01的容器,容器dc01继承容器dc00的数据卷。
其中dc00也是由此镜像创建。
这种用法可以用于搭建redis集群等情况。