Docker[4]-Docker数据卷

数据卷

前面我们介绍了镜像和容器,通过镜像我们可以启动多个容器,但是我们发现当我们的容器停止获取删除后,我们在容器中的应用的一些数据也丢失了,这时为了解决容器的数据持久化,我们需要通过容器数据卷来解决这个问题

1 数据卷是什么

  Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。简单来说,容器卷就相当于Redis中持久化方式的RDB和AOF。

2 解决了什么问题

  卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:   卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

特点:

  1. 数据卷可在容器之间共享或重用数据

  2. 卷中的更改可以直接生效

  3. 数据卷中的更改不会包含在镜像的更新中

  4. 数据卷的生命周期一直持续到没有容器使用它为止

持久化,容器间继承和共享数据

 数据卷使用

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之间数据还是共享的

 

 

 

 

注意:容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值