容器数据卷是什么

先来看看Docker的理念:

  1. 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的
  2. 容器之间希望有可能共享数据

Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来,那么当容器删除后,数据自然也就没有了。为了能保存数据在docker中我们使用卷。

能干嘛

卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System提供一些用于持续存储或共享数据的特性:

卷的设计目的就是数据的持久化,完全独立于容器的生存周期,因此Docker不会在容器删除时删除其挂载的数据卷

特点:

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

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

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

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

数据卷的添加

1、以直接命令方式添加docker run -it -v /宿主机目录:/容器内目录 centos /bin/bash**

这里我设置了 宿主机目录mDataVolume ; 容器内目录dataVolumeContainer

执行命令 docker run -it -v /mDataVolume:/dataVolumeContainer centos /bin/bash

在这里插入图片描述
此时查看docker容器中根目录文件,发现了此时出现了dataVolumeContainer
在这里插入图片描述
查看数据卷是否挂载成功----用json的形式描述docker。 命令:docker inspect 容器ID
在这里插入图片描述
容器和宿主机之间数据共享在这里插入图片描述

容器停止退出后,主机修改后数据是否同步
在这里插入图片描述在这里插入图片描述

带权限命令 docker run -it -v /mDataVolume:/dataVolumeContainer:ro centos /bin/bash
在这里插入图片描述

2、DockerFile方式添加

1、根目录下新建mydocker 并进入

2、在mydocker目录中,新建文件DockerFile

可在DockerFile中使用volume来给镜像添加一个或者多个数据卷
在这里插入图片描述
3、File构建:在文件中编写以下代码

# volume test

FROM centos

VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]

CMD echo "finished,--------success1"

CMD /bin/bash

4、build后生成一个新的镜像–>lcy/centos
在这里插入图片描述
5、 run 容器
在这里插入图片描述
6、在新建容器卷的时候,我们并没有指定对应宿主机的目录地址,那么默认的地址在哪里呢 ?
在这里插入图片描述
在这里插入图片描述

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐