Docker知识点(四):Docker数据卷

2022-10-11 22:45:29 浏览数 (1)

1. 数据卷

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

1.1 数据卷是什么

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

1.2 解决了什么问题

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

特点:

  1. 数据卷可在容器之间共享或重用数据
  2. 卷中的更改可以直接生效
  3. 数据卷中的更改不会包含在镜像的更新中
  4. 数据卷的生命周期一直持续到没有容器使用它为止

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

1.3 数据卷使用

1.3.1 直接添加

运行一个centos容器

代码语言:javascript复制
docker run -it -v /宿主机绝对路径:/容器内目录 镜像名

在宿主机的根目录下会多出对应的文件夹

然后在容器的根目录下也会出现对应的文件夹

通过inspect命令可以查询容器的详情

数据共享的操作

宿主机添加对应的文件

容器中查看

容器中可以同步看到,然后在容器中修改数据

停止掉容器后,数据依然存在

权限控制:不允许在容器中修改

修改权限

代码语言:javascript复制
docker run -it -v /宿主机绝对路径:/容器目录:ro 镜像名

1.3.2 DockerFiler添加

宿主机跟目录下创建一个mydocker,并在该目录下创建一个文件,内容如下

代码语言:javascript复制
# volume test
​
FROM centos
​
VOLUME ["/dataVolumeContainer1","/dataVolumeContainer2"]
​
CMD echo "finished,--------success1"
​
CMD /bin/bash
​

根据这个DockerFile构建我们的镜像文件

代码语言:javascript复制
docker build -f dockerFile1 -t bobo/centos .

-f DockerFile文件的路径

-t 标签

. 当前路径

根据新创建的镜像文件创建一个容器,启动后我们可以看到在容器中创建的有对应的目录

这两个目录和宿主机的映射目录在哪呢?这时我们可以通过 inspect命令查看

验证就只需要在宿主机中创建文件,然后再到容器对应的文件夹中查看即可

2. 数据卷容器

命名的容器挂载数据卷,其他容器通过挂载这个容器实现数据共享,挂载数据的容器,称之为数据卷容器。

2.1 启动一个父容器

代码语言:javascript复制
docker run -it --name dc01 bobo/centos

2.2 创建两个子容器

代码语言:javascript复制
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之间数据还是共享的

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

3. DockerFile

DockerFile是用来构建Docker镜像的构建文件,是由一系列命令参数构成的脚本

代码语言:javascript复制
FROM scratch
ADD centos-7-x86_64-docker.tar.xz /
​
LABEL 
    org.label-schema.schema-version="1.0" 
    org.label-schema.name="CentOS Base Image" 
    org.label-schema.vendor="CentOS" 
    org.label-schema.license="GPLv2" 
    org.label-schema.build-date="20201113" 
    org.opencontainers.image.title="CentOS Base Image" 
    org.opencontainers.image.vendor="CentOS" 
    org.opencontainers.image.licenses="GPL-2.0-only" 
    org.opencontainers.image.created="2020-11-13 00:00:00 00:00"
​
CMD ["/bin/bash"]

3.1. 构建过程

Dockerfile中的指令需要满足如下的规则

3.2 执行流程

  docker执行一个Dockerfile脚本的流程大致如下:

  1. docker从基础镜像运行一个容器
  2. 执行一条指令并对容器作出修改
  3. 执行类似docker commit的操作提交一个新的镜像层
  4. docker再基于刚提交的镜像运行一个新的容器
  5. 执行dockerfile中的下一条指令直到所有指令都执行完成

从应用软件的角度来看,Dockerfile、Docker镜像与Docker容器分别代表软件的三个不同阶段,

  • Dockerfile是软件的原材料
  • Docker镜像是软件的交付品
  • Docker容器则可以认为是软件的运行态。

Dockerfile面向开发,Docker镜像成为交付标准,Docker容器则涉及部署与运维,三者缺一不可,合力充当Docker体系的基石。

  1. Dockerfile,需要定义一个Dockerfile,Dockerfile定义了进程需要的一切东西。Dockerfile涉及的内容包括执行代码或者是文件、环境变量、依赖包、运行时环境、动态链接库、操作系统的发行版、服务进程和内核进程(当应用进程需要和系统服务和内核进程打交道,这时需要考虑如何设计namespace的权限控制)等等;
  2. Docker镜像,在用Dockerfile定义一个文件之后,docker build时会产生一个Docker镜像,当运行 Docker镜像时,会真正开始提供服务;
  3. Docker容器,容器是直接提供服务的。

3.3 DockerFile案例

我们从官方pull下来的centos是没有vim命令的,我们可以自定义一个镜像,功能比官方提供的强大一点即可

创建DockerFile文件

代码语言:javascript复制
FROM centos
MAINTAINER bobo<dengpbs163.com>
​
​
ENV MYPATH /usr/local
WORKDIR $MYPATH
​
RUN yum -y install vim
​
EXPOSE 80
CMD echo $MYPATH
CMD echo "success ------- 66666"
CMD /bin/bash
​

构建镜像文件

代码语言:javascript复制
docker build -f DockerFile文件路径 -t 镜像名称:tag .

运行容器

代码语言:javascript复制
docker run -it bobo/centos7:1.7

0 人点赞