数据卷
前面我们介绍了镜像和容器,通过镜像我们可以启动多个容器,但是我们发现当我们的容器停止获取删除后,我们在容器中的应用的一些数据也丢失了,这时为了解决容器的数据持久化,我们需要通过容器数据卷来解决这个问题
1 数据卷是什么
Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。简单来说,容器卷就相当于Redis中持久化方式的RDB和AOF。
2 解决了什么问题
卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性: 卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷
特点:
-
数据卷可在容器之间共享或重用数据
-
卷中的更改可以直接生效
-
数据卷中的更改不会包含在镜像的更新中
-
数据卷的生命周期一直持续到没有容器使用它为止
持久化,容器间继承和共享数据
数据卷使用
1 直接添加
运行一个centos容器
docker run -it -v /宿主机绝对路径:/容器内目录 镜像名
在宿主机的根目录下会多出对应的文件夹
然后在容器的根目录下也会出现对应的文件夹
通过inspect命令可以查询容器的详情
数据共享的操作
宿主机添加对应的文件
容器中查看
容器中可以同步看到,然后在容器中修改数据
停止掉容器后,数据依然存在
权限控制:不允许在容器中修改
修改权限
docker run -it -v /宿主机绝对路径:/容器目录:ro 镜像名
2 DockerFiler添加
宿主机跟目录下创建一个mydocker,并在该目录下创建一个文件,内容如下
# volume test FROM centos VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"] CMD echo "finished,--------success1" CMD /bin/bash
根据这个DockerFile构建我们的镜像文件
docker build -f dockerFile1 -t bobo/centos .-f DockerFile文件的路径
-t 标签
. 当前路径
根据新创建的镜像文件创建一个容器,启动后我们可以看到在容器中创建的有对应的目录
这两个目录和宿主机的映射目录在哪呢?这时我们可以通过 inspect命令查看
验证就只需要在宿主机中创建文件,然后再到容器对应的文件夹中查看即可
3数据卷容器
命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据的容器,称之为数据卷容器。
1.启动一个父容器
docker run -it --name dc01 bobo/centos
2.创建两个子容器
docker run -it --name dc02 --volumes-from dc01 bobo/centos docker run -it --name dc03 --volumes-from dc01 bobo/centos
创建了两个子容器后,首先都可以看到dc01中的共享资源。第二个在dc01中修改了共享资源文件后,在两个容器中也是可见的。
注意,删除dc01后,dc02和dc03之间数据还是共享的
注意:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止。