zoukankan      html  css  js  c++  java
  • Docker容器数据卷

    卷是什么

    Docker容器产生的数据,如果不通过docker commit生成新的镜像,使得数据作为镜像的一部分保存下来,那么当容器删除后,数据也就没有了。

    卷便是保存数据的方式。

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

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

    特点:

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

    添加数据卷

    使用 -v参数添加

    例如:docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名 可以添加多个数据卷

    挂载后,主机与容器之间数据可以进行共享。

    挂载的卷在容器内是可读可写的,也可以指定为只读

    docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名

    使用Dockerfile添加

    创建一个名为DockerFile的文件,添加如下内容

    FROM centos
    VOLUME ["/dataVolume1","/dataVolume2"]
    CMD echo "finished,----success"
    CMD /bin/bash
    

    上面的内容等效于docker run -it /host1:/dataVolume1 /host2:/dataVolume2 centos /bin/bash

    构建docker build -f DockerFile -t 自定义镜像名会构建一个挂载了卷的镜像,启动docker run -it 镜像名,进入容器就能看到挂载的目录。

    如果挂载主机目录Docker访问出现cannot open directory:Permission denied,在挂载目录后多加一个--privileged=true

    容器数据卷volumes-from

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

    现有一个容器dc01,我们可以启动另外两个容器dc02,dc03,继承dc01,使得数据在三个容器之间共享。

    docker run -it --name dc02 --volumes-from dc01 镜像名

    docker run -it --name dc03 --volumes-from dc01 镜像名

    无论共享中,哪个容器关闭,都不会影响剩余容器之间的数据共享。数据卷的生命周期一直持续到没有容器使用它为止。

  • 相关阅读:
    [bzoj2654]tree_二分_kruskal
    [luogu1373]小a和uim之大逃离_动态规划
    [luogu1156]垃圾陷阱_动态规划_背包dp
    [luogu2209][USACO13]燃油经济性Fuel Economy_贪心
    UNIX环境高级编程——进程基本概述
    UNIX环境高级编程——进程控制
    UNIX环境高级编程——进程环境
    UNIX环境高级编程——时间和日期
    UNIX环境高级编程——Linux进程地址空间和虚拟内存
    UNIX环境高级编程——标准I/O库函数和Unbuffered I/O函数
  • 原文地址:https://www.cnblogs.com/ylcc-zyq/p/13275652.html
Copyright © 2011-2022 走看看