使用Dockerfile实现数据卷的挂载问题(推荐)

大家好,我们今天分享使用Dockerfile来实现数据卷的挂载

首先呢,要了解一下什么是Dockerfile

Dockerfile就是 一个可以用来构建镜像的文件,可以理解为一个脚本文件

可以通过这个脚本文件自定义生成一个我们想要的镜像,镜像都是一层一层的,里面的每一条命令就是一层

创建一个目录

root@localhost home]# mkdir  docker-vl2

编辑这样这样的一个文件

root@localhost docker-vl2]# vim dockerfile01
FROM centos
VOLUME ["volume01","volume02"]

CMD echo "------end-----"
CMD /bin/bash
~
~
~
~       

保存退出:

构建成新的镜像,注意看shuaige/centos:2.0有一个小点

[root@localhost docker-vl2]# docker build -f dockerfile01 -t shuaige/centos:2.0 .
Sending build context to Docker daemon  2.048kB
Step 1/4 : FROM centos
 ---> 5d0da3dc9764
Step 2/4 : VOLUME ["volume01","volume02"]
 ---> Running in 96445950bbef
Removing intermediate container 96445950bbef
 ---> ffcf0eb8973b
Step 3/4 : CMD echo "------end-----"
 ---> Running in a4fa6fce633b
Removing intermediate container a4fa6fce633b
 ---> 5416582373e0
Step 4/4 : CMD /bin/bash
 ---> Running in 7d7df79e0b36
Removing intermediate container 7d7df79e0b36
 ---> d8e0f44b8da3
Successfully built d8e0f44b8da3
Successfully tagged shuaige/centos:2.0

看这个过程,一共有4步,对应着我们刚刚写的dockerfile 文件

也是一层一层的

查看镜像:

这样,我们的这个dockerfile 文件就构建成功了

进入我们自己写的容器

[root@localhost docker-vl2]# docker run -it d8e0f44b8da3   /bin/bash
[root@b36bc0c1e4a9 /]#

查看容器内部的文件结构:

[root@b36bc0c1e4a9 /]# ls -l
total 0
lrwxrwxrwx.   1 root root   7 Nov  3  2020 bin -> usr/bin
drwxr-xr-x.   5 root root 360 Mar  8 14:09 dev
drwxr-xr-x.   1 root root  66 Mar  8 14:09 etc
drwxr-xr-x.   2 root root   6 Nov  3  2020 home
lrwxrwxrwx.   1 root root   7 Nov  3  2020 lib -> usr/lib
lrwxrwxrwx.   1 root root   9 Nov  3  2020 lib64 -> usr/lib64
drwx------.   2 root root   6 Sep 15 14:17 lost+found
drwxr-xr-x.   2 root root   6 Nov  3  2020 media
drwxr-xr-x.   2 root root   6 Nov  3  2020 mnt
drwxr-xr-x.   2 root root   6 Nov  3  2020 opt
dr-xr-xr-x. 265 root root   0 Mar  8 14:09 proc
dr-xr-x---.   2 root root 162 Sep 15 14:17 root
drwxr-xr-x.  11 root root 163 Sep 15 14:17 run
lrwxrwxrwx.   1 root root   8 Nov  3  2020 sbin -> usr/sbin
drwxr-xr-x.   2 root root   6 Nov  3  2020 srv
dr-xr-xr-x.  13 root root   0 Mar  4 07:14 sys
drwxrwxrwt.   7 root root 171 Sep 15 14:17 tmp
drwxr-xr-x.  12 root root 144 Sep 15 14:17 usr
drwxr-xr-x.  20 root root 262 Sep 15 14:17 var
drwxr-xr-x.   2 root root   6 Mar  8 14:09 volume01
drwxr-xr-x.   2 root root   6 Mar  8 14:09 volume02

可以看见这俩行:(这就是我们刚才使用dockerfile 文件做的数据卷挂载)

drwxr-xr-x.   2 root root   6 Mar  8 14:09 volume01
drwxr-xr-x.   2 root root   6 Mar  8 14:09 volume02

看dockerfile 文件的内容:

FROM centos
VOLUME ["volume01","volume02"]

CMD echo "------end-----"
CMD /bin/bash
~

可以看出,它是匿名挂载:

但凡是挂载,就是一定与外部有一个对应的目录

查看正在运行的容器

[root@localhost ~]# docker ps
CONTAINER ID   IMAGE          COMMAND                  CREATED             STATUS             PORTS                                     NAMES
b36bc0c1e4a9   d8e0f44b8da3   "/bin/bash"              14 minutes ago      Up 14 minutes                                                compassionate_brown
6590da464b6e   nginx          "/docker-entrypoint.…"   About an hour ago   Up About an hour   0.0.0.0:49154->80/tcp, :::49154->80/tcp   nginx03
d8e9b9084cf8   nginx          "/docker-entrypoint.…"   2 hours ago         Up 2 hours         0.0.0.0:49153->80/tcp, :::49153->80/tcp   nginx02
6d6fa6a4c6d7   5d0da3dc9764   "/bin/bash"              33 hours ago        Up 33 hours                                                  nice_panini

看容器的系统信息

[root@localhost ~]# docker inspect b36bc0c1e4a9

这就是我们刚才数据卷挂载的位置

 "Mounts": [
            {
                "Type": "volume",
                "Name": "155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1",
                "Source": "/var/lib/docker/volumes/155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1/_data",
                "Destination": "volume01",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            },
            {
                "Type": "volume",
                "Name": "1c6664c1368e4a11d36fd0b629c5e7b7d40d1d2f88322f9188383e92e52aa2f1",
                "Source": "/var/lib/docker/volumes/1c6664c1368e4a11d36fd0b629c5e7b7d40d1d2f88322f9188383e92e52aa2f1/_data",
                "Destination": "volume02",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ],

在容器内部新建一个文件

[root@b36bc0c1e4a9 /]# cd volume01
[root@b36bc0c1e4a9 volume01]# touch hsud.txt
[root@b36bc0c1e4a9 volume01]#

看系统信息:

[root@localhost _data]# docker inspect b36bc0c1e4a9

在Linux主机上看容器中看

[root@localhost ~]# cd /var/lib/docker/volumes/155842f6ab8581ad5d04fa25d6a1979647f481aad9532306834e577f88daa2a1/_data
[root@localhost _data]# ls
hsud.txt
[root@localhost _data]#

好了,这样我们就做好了,有关于使用Dockerfile实现数据卷的挂载就到这里了,谢谢大家了

到此这篇关于使用Dockerfile实现数据卷的挂载的文章就介绍到这了,更多相关Dockerfile数据卷挂载内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Dockerfile中的保留字指令的过程解析

    目录 一.Dockerfile是什么? 二.Dockerfile构建过程分析 三.Dockerfile保留字指令 3.1.FROM 3.2.MAINTAINER 3.3.RUN 3.4.EXPOSE 3.5.WORKDIR 3.6.ENV 3.7.ADD 和 COPY 3.8.VOLUME 3.9.CMD 和 ENTRYPOINT 3.10.ONBUILD 四.实战案例 4.1.制作一个自己的Centos镜像 4.1.1.引入: 4.1.2.编写Dockerfile文件 4.1.3.构建cent

  • Dockerfile常用命令的使用简介

    之前的文章中,我们已经说了RUN.FROM.MAINTAINER.EXPOSE等一些DockerFile的相关命令,今天我们来看DockerFile的其他命令介绍. 01 CMD CMD命令用于指定一个容器启动的时候需要运行的命令.它和RUN指令有点类似,但是不同之处在于: RUN指令是镜像被构建的时候,需要执行的命令: CMD指令是指定容器被启动的时候,要运行的指令.举例: docker run -it container_name /bin/ls 这个命令是我们启动一个容器,并且运行/bin

  • 使用Dockerfile构建docker镜像

    今天我们看看Dockerfile创建的方法. 构建docker镜像,有两种方法: 1.一种是使用docker commit命令 2.另外一种是基于docker build命令和dockerfile文件 通常情况下,dockerfile构建镜像比docker commit命令构建 镜像更加灵活,因此采用后者较多. 使用Dockerfile构建docker镜像 1.什么是Dockerfile? dockerfile是一个文件,它是使用DSL语法编写一个文件,之后使用docker build命令基于该

  • Docker中Dockerfile制作镜像的方法步骤

    目录 1.基于容器制作 2. 基于Dockerfile制作镜像 2.1 Dockerfile命令 2.2 简单示例 docker 镜像的制作,可以基于容器创建镜像,也可基于 dockerfile 构建镜像.但需要注意的是,我们并不是真正"创建"新镜像,而是基于一个已有的基础镜像,如 centos 或 ubuntu 等,构建新镜像而已. 1.基于容器制作 联合文件系统(UnionFS)挂载提供了容器的文件系统,任何对容器内文件系统的改动都会被写入到新的文件层中,这个文件层归创建它的容器所

  • 使用Dockerfile实现数据卷的挂载问题(推荐)

    大家好,我们今天分享使用Dockerfile来实现数据卷的挂载 首先呢,要了解一下什么是Dockerfile Dockerfile就是 一个可以用来构建镜像的文件,可以理解为一个脚本文件 可以通过这个脚本文件自定义生成一个我们想要的镜像,镜像都是一层一层的,里面的每一条命令就是一层 创建一个目录 root@localhost home]# mkdir docker-vl2 编辑这样这样的一个文件 root@localhost docker-vl2]# vim dockerfile01 FROM

  • 浅谈Docker 容器数据卷挂载小结

    为了更直观了解数据卷挂载的操作,做个实验一一验证数据卷挂载的各种情况. 情况一.本地不存在文件挂载到容器存在文件 首先是当本地不存在该文件,而容器内存在该文件的情况,尝试把不存在的文件挂载到存在该文件的容器中.以一个 Alpine 镜像为例,这里把一个修改后的 Alpine 镜像打了新标签,叫做 volume_test: # 本地目录不存在 test 文件. $ docker run --name=test -v ~/test.txt:/etc/hosts -d volume_test 0cba

  • docker挂载本地目录和数据卷容器操作

    1.docker挂载本地目录 docker可以支持把一个宿主机上的目录挂载到镜像里. 交互模式运行 docker run -it -v /home/dock/Downloads:/usr/Downloads ubuntu64 /bin/bash 后台运行 docker run -d -v /home/dock/Downloads:/usr/Downloads --name ubuntu1 ubuntu64 通过-v参数,冒号前为宿主机目录,必须为绝对路径,冒号后为镜像内挂载的路径. 现在镜像内就

  • docker容器数据卷之具名挂载和匿名挂载问题

    目录 什么是容器数据卷 为什么需要容器数据卷 使用 如何查看是否使用了数据卷 具名挂载和匿名挂载 指定路径挂载 具名挂载 匿名挂载 容器与容器之间的数据共享 --volumes-from 什么是容器数据卷 容器数据卷就是目录的挂载,将我们的容器的目录挂载到宿主机上,从而实现打通宿主机和容器之间的文件共享功能: 为什么需要容器数据卷 docker理念就是将应用和环境打包成一个镜像:但是数据怎么办呢?且不说数据库,一个项目在运行过程种肯定会产生大量的日志,这些日志对开发人员来说是非常重要的, 因为有

  • docker 数据卷之进阶篇

    笔者在<Docker 基础 : 数据管理>一文中介绍了 docker 数据卷(volume) 的基本用法.随着使用的深入,笔者对 docker 数据卷的理解与认识也在不断的增强.本文将在前文的基础上介绍 docker 数据卷的原理及一些高级用法.如果您想先了解 docker 数据卷的基本概念与用法,请先移步这里. 为什么需要数据卷? 这得从 docker 容器的文件系统说起.出于效率等一系列原因,docker 容器的文件系统在宿主机上存在的方式很复杂,这会带来下面几个问题: 不能在宿主机上很方

  • Docker 数据卷操作的实现

    数据卷入门 在前面的案例中,如果我们需要将数据从宿主机拷贝到容器中,一般都是使用 Docker 的拷贝命令,这样性能还是稍微有点差,没有办法能够达到让这种拷贝达到本地磁盘 I/O 性能呢?有! 数据卷可以绕过拷贝系统,在多个容器之间.容器和宿主机之间共享目录或者文件,数据卷绕过了拷贝系统,可以达到本地磁盘 I/O 性能. 本文先通过一个简单的案例向读者展示数据卷的基本用法. 以前面使用的 nginx 镜像为例,在运行该容器时,可以指定一个数据卷,命令如下: docker run -itd --n

  • Docker数据卷和容器编排的使用

    前言 Docker 数据卷和容器编排,记录下来! 数据卷 数据卷可以绕过拷贝系统,在多个容器之间.容器和宿主机之间共享目录或文件,数据卷绕过了拷贝系统,可以达到本地磁盘I/O性能. 运行容器时,指定一个数据卷 $ docker run -itd --name nginx -v /usr/share/nginx/html/ -p 80:80 e445ab08b2be 此时,我们创建了一个数据卷并且挂载到容器的/usr/share/nginx/html/目录下. 使用 docker inspect

  • 详解Docker容器数据卷

    是什么 先来看看Docker的理念: 将运用与运行的环境打包形成容器运行,运行可以伴随着容器,但是我们对数据的要求希望是持久化的容器之间希望有可能共享数据 Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据做为镜像的一部分保存下来, 那么当容器删除后,数据自然也就没有了. 为了能保存数据在docker中我们使用卷. 一句话:有点类似我们Redis里面的RDB和AOF 能干嘛 卷就是目录或文件,存在于一个或多个容器中,由docker挂载到容器,但不属于联合文件系

  • Docker容器数据卷介绍及操作示例

    目录 容器数据卷介绍 什么是数据卷 数据卷能做什么? 特点 Docker 容器数据卷操作 直接命令添加数据卷 dockerfile 添加数据卷 Docker 数据卷容器 数据卷容器简介 案例演示 容器数据卷介绍 什么是数据卷 将运用与运行的环境打包形成容器运行,运行可以伴随着容器,但是我们对数据的要求是持久化的. 容器之间希望有可能共享数据. Docker 容器产生的数据,如果不通过 docker commit 生成新的镜像,使得数据做为镜像的一部分保存下载,那么当容器删除后,数据自然也就没有了

  • Docker中容器数据卷详解

    目录 什么是容器数据卷 数据的覆盖问题 使用数据卷 方式一:直接使用命令挂载 -v 测试挂载卷 方式二:Dockerfile文件 数据卷命令 查看数据卷 方式一:docker inspect 容器ID 方式二:docker volume inspect juming-nginx 挂载三种方式 扩展 什么是容器数据卷 从docker的理念说起,docker将应用和环境打包成一个镜像,运行镜像(生成容器)就可以访问服务了. 如果数据都存在容器中,那么删除容器,数据就会丢失!需求:数据可以持久化 My

随机推荐