前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker知识点(四):Docker数据卷

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

原创
作者头像
Java鱼头
发布2022-10-11 22:45:29
1K0
发布2022-10-11 22:45:29
举报
文章被收录于专栏:Java-doc

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

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1. 数据卷
    • 1.1 数据卷是什么
      • 1.2 解决了什么问题
        • 1.3 数据卷使用
          • 1.3.1 直接添加
          • 1.3.2 DockerFiler添加
      • 2. 数据卷容器
        • 2.1 启动一个父容器
          • 2.2 创建两个子容器
          • 3. DockerFile
            • 3.1. 构建过程
              • 3.2 执行流程
                • 3.3 DockerFile案例
                相关产品与服务
                容器服务
                腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档