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

    Docker容器数据卷是什么?

    Docker的理念:

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

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

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

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

    特点:

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

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

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

    4. 数据卷的声明周期一直持续到没有容器使用它为止。

    在容器内添加数据卷

    直接命令添加: 

    docker run -it -v /宿主机绝对路径目录:/容器内目录  镜像名
    
    带权限
    docker run -it -v /宿主机绝对路径目录:/容器内目录:ro 镜像名  #只读 Read-only

    dockerfile添加

    1. 根目录下新建mydocker文件夹并进入
    
    2. 可在Dockerfile中使用VOLUME指令来给镜像添加一个或多个数据卷
    VOLUME["/dataVolumeContainer", "/dataVolumeContainer2", "/dataVolumeContainer3"]
    说明: 出于可移植和分享的考虑,用-v主机目录: 容器目录这种方法不能直接在Dockerfile中实现。由于宿主机目录是依赖于特定宿主机的,并不能够保证在所有宿主机上都存在这一的特定目录
    
    3. file构建
    # volume test
    FROM centos
    VOLUME["/dataVolumeContainer", "/dataVolumeContainer2"]
    CMD echo "finished, -------success1"
    CMD /bin/bash
    
    4. build后生成镜像
    docker build -f /mydocker/dockerfile -t feather/centos .
    
    5. run 容器
    docker run -it feather/centos
    
    # 备注:
    Docker挂载主机目录Docker访问出现cannot open directory .: Permission denied
    解决办法: 在挂载目录后多加一个--privileged=true参数即可

    数据卷容器

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

    容器间传递共享(--volumes-from)

    1. 先启动一个父容器dc01, 在dataVolumeContainer2新增内容
    
    2. dc02/dc03继承自dc01
    docker run --name dc02 --volumes-from dc01 feather/centos
    docker run --name dc02 --volumes-from dc01 feather/centos
    
    总结: 容器之间配置信息的传递,数据卷的生命周期一直持续到没有容器使用它为止

     

  • 相关阅读:
    eclipse新建web项目开发JSP
    配置tomcat系统日志--java eclipse
    Eclipse 导入外部项目无法识别为web项目并且无法在部署到tomcat下
    for和foreace的区别
    布局TextView和EditText区别,layout_width和lay_weight区别--Android Studio
    设备旋转,创建水平模式布局--Android studio
    关于点击Invalidate Caches/Restart禁止插件后,重新加载--Android Studio
    Android 全面插件化 RePlugin 流程与源码解析
    git分支开发,分支(feature)同步主干(master)代码,以及最终分支合并到主干的操作流程
    git使用流程
  • 原文地址:https://www.cnblogs.com/featherwit/p/12960484.html
Copyright © 2011-2022 走看看