4、Docker容器数据卷,容器和宿主机实现数据共享
Docker容器数据卷,容器和宿主机实现数据共享
一、是什么
在了解容器卷之前,咱们先来看看Docker的理念:
- 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的
- 容器之间希望有可能共享数据
我们想象一下,Docker容器运行后,产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。
所以,为了能保存数据,在docker中我们就要使用数据卷。
也可以这么理解:有点类似我们Redis里面的rdb和aof文件。
二、能干嘛
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:
卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
1:数据卷可在容器之间共享或重用数据
2:卷中的更改可以直接生效
3:数据卷中的更改不会包含在镜像的更新中
4:数据卷的生命周期一直持续到没有容器使用它为止。
容器的持久化
容器间继承+共享数据
三、数据卷
容器内添加,主要有两种方式:
第一种:直接命令添加
命令:
docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名
下面咱们进行直观的展示
具体要求,我想在宿主机根目录下创建一个hostDir目录,与容器的根目录下创建containerDir目录,进而让两者进行数据共享。
1、首先,咱们看一下,宿主机根目录下的文件目录,此时是没有hostDir目录的。
2、查看宿主机的镜像,咱们使用centos镜像
3、执行挂载数据卷的命令
docker run -it -v /hostDir:/containerDir centos /bin/bash
4、查看容器内部的目录变化
5、查看宿主机目录的变化
6、查看数据卷是否挂载成功
命令:docker inspect 容器ID
如何实现数据共享呢?
1、首先,咱们在容器的containerDir目录下,创建一个1.txt文件,并编辑内容
2、然后,咱们来到宿主机的hostDir下,查看是否也有1.txt文件,并查看里面的内容
看到这里,说明容器和宿主机的数据已经实现了同步和共享
3、现在呢,咱们反过来,在宿主机上,先创建一个2.txt,同时呢修改一下1.txt
4、最后,咱们进入容器中进行查看,是否也有2.txt,同时呢1.txt是否也被修改
再加深一下,如果容器停止退出后,咱们在宿主机修改后数据后,再次启动容器,数据是可以同步的。这就类似我们Redis里面的rdb和aof文件。
第二种:DockerFile添加
可在Dockerfile中使用VOLUME指令来给镜像添加一个或多个数据卷
VOLUME["/dataVolumeContainer","/dataVolumeContainer2","/dataVolumeContainer3"]
说明:
出于可移植和分享的考虑,用-v 主机目录:容器目录这种方法不能够直接在Dockerfile中实现。
由于宿主机目录是依赖于特定宿主机的,并不能够保证在所有的宿主机上都存在这样的特定目录。
来来,咱们继续进行演示
1、在宿主机根目录下,创建一个mydocker文件夹并进入
2、创建一个dockerFile文件,并编辑内容
# volume test
FROM centos
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
CMD echo "finished,--------success1"
CMD /bin/bash
3、build后生成镜像,获得一个新镜像wzy/centos
docker build -f /mydocker/dockerFile -t wzy/centos .
4、运行这个新的容器,然后查看容器内部目录变化
docker run -it 4e5d0ca682c2 /bin/bash
此时可以看到,容器根目录下,已经创建出了两个文件夹。
5、通过上述步骤,容器内的卷目录地址已经知道,对应的主机目录地址哪???
咱们可以通过一个命令进行查看得到
docker inspect 容器id
docker inspect c3803db06963
这俩就是相互对应的绑定关系
6、验证一下,宿主机的目录
这个目录确实是在宿主机存在的,下一步就可以做数据共享了。
更多推荐
所有评论(0)