一,docker容器面临的困境:

  • 容器运行中产生的数据,是放到容器栈的最顶层,当容器停止并被删除后,这些数据就被删除了。
  • docker采用COW(写时复制)策略,导致性能低下。比如有个mysql容器,会有频繁的I/O处理。

二,解决策略:给容器外挂一个存储文件系统,它就叫docker存储卷(Volumes),它独立于容器的生命周期,删除容器时不会删除卷(让然也可以做到,删除容器的时候也删除卷,但没有这么干的)。

让容器里面的某个目录绑定到宿主机的某个目录。

容器写数据时,写到/下的数据,最后被写到了容器的可读写层;写到/data下的数据,最后被写到了宿主机的/data目录下了。如下图:

下图的宿主机A,B,C是文件系统NFS的客户端。宿主机A的文件目录A,宿主机B的文件目录B,宿主机C的文件目录C,都是访问NFS上的同一个目录。

使用docker存储卷功能,让宿主机A上运行的mysql容器,产生的数据目录,绑定到宿主机A的文件目录A,所以当由mysql容器产生的数据,就存放到了宿主机A的文件目录A上了,进而就存到到了NFS上了。

当宿主机A上运行的mysql容器被删除了,数据还是在的,存在NFS上了。

当在宿主机B或者宿主机C上运行刚才那个mysql容器,也让产生的数据目录,绑定到宿主机B或者宿主机C,可以从NFS上可以拿到数据,所以数据和在宿主机A上运行是一样的。

这就给运维提供了极大的便利,容器可以随便部署到集群里的任何机器上了。

可以用【存储】,【状态】来划分4个象限。

nginx只作为反向代理服务器,所以它没有状态也不需要存储。

三,docker存储卷有2种策略,都是使用-v选项。

  • bind mount volume:手动指定宿主机目录。

    命令:docker run -v HOSTDIR:CONTAINERDIR

    #  docker run --name b1 -it --rm -v /tmp/html:/data busybox:latest
  • docker-managed volume:由docker自己决定宿主机目录。

    命令:docker run -v CONTAINERDIR

    # docker run --name b1 -it --rm -v /data busybox:latest

    我们不知道被关联的宿主机的目录是啥,使用docker inspect b1,找到【Mount】里的【Source】,就可以看到了。但是你下次再启动容器是,关联的目录也会变化。

    也可以看到Volumes。

    # docker inspect b1
    "Mounts": [
    {
    "Type": "volume",
    "Name": "2eeb1bdee5c83a304d101a98b06430af3aff27a578ad38c7e23423f317db9063",
    "Source": "/var/lib/docker/volumes/2eeb1bdee5c83a304d101a98b06430af3aff27a578ad38c7e23423f317db9063/_data",
    "Destination": "/data",
    "Driver": "local",
    "Mode": "",
    "RW": true,
    "Propagation": ""
    }
    ],
    "Volumes": {
    "/data": {}
    },

    使用:docker inspect -f {{.Mounts}} b1,也可以看到。注意大括号里的key是区分大小写的。

四,活用volume

  • 让2个容器绑定到宿主机的同一个目录,以达到2个容器的通信。

    # docker run --name b1 -it --rm -v /tmp/html:/data busybox:latest
    # docker run --name b2 -it --rm -v /tmp/html:/data2 busybox:latest

    2个容器都绑定到了宿主机的/tmp/html上了。

  • 当另一个容器想和某个容器绑定到宿主机的同一个目录时,但是又不知道宿主机的目录,这时,可以让这个容器直接使用某个容器的volume,这样一来,就不用知道宿主机的目录了。

    命令:docker run --volumes-from b1

    # docker run --name b2 -it --rm --volumes-from b1 busybox:latest
  • volume和joined containers(参考:二,host章节 )一起使用,创建nginx容器和tomcat容器,共享base容器的网络空间和volume。

    • 找一个容器,作为基础,它使命是:

      • 指定宿主机的目录
      • 提供统一的对外网络接口,外部客户端直接可以访问nginx服务,但是看不到tomcat
      • nginx和tomcat使用lo(127.0.0.1)通信。
      # docker run --name base -it -v /tmp/html:/data busybox:latest
    • 启动nginx容器:--network container:base --volumes-from base

      # docker run --name nginx -it --rm --network container:base --volumes-from base busybox:latest
    • 启动tomcat容器:--network container:base --volumes-from base

      # docker run --name tomcat -it --rm --network container:base --volumes-from base busybox:latest

c/c++ 学习互助QQ群:877684253

本人微信:xiaoshitou5854

docker 存储卷 Volumes的更多相关文章

  1. Docker系列05—Docker 存储卷详解

    本文收录在容器技术学习系列文章总目录 1.存储卷介绍 1.1 背景 (1)docker 的 AFUS 分层文件系统 docker镜像由多个只读层叠加面成,启动容器时,docker会加载只读镜像层并在镜 ...

  2. 6、Docker存储卷

    Why Data Volumes?  来自马哥教育 Data volumes Volume types  绑定挂载卷:在宿主机和容器上各指明绑定路径才能进行绑定. docker管理卷:在容器内指定挂载 ...

  3. Docker存储卷(V18.X)

    简介 介绍 Docker的存储卷称之为volume,本质上容器上的一个或者多个目录,而这些目录绕过了联合文件系统,与宿主机中的目录或者其他容器目录进行了绑定关系,这种绑定关系可以看作Linux的mou ...

  4. Docker存储卷

    六.Docker 存储卷(volume) COW:写时复制 Bind mount volume:手动mount绑定的卷 # docker run --name centos-3 -it -v /dat ...

  5. Docker存储卷篇

    Docker存储卷篇 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.    一.写时复制(COW)机制 所谓写时复制的效果如上图所示: Docker镜像由多个只读层叠加而成,启动容器 ...

  6. Docker 学习6 Docker存储卷

    一.什么是存储卷 二.为什么要用到数据卷 三.数据卷是怎么被管理的 四.存储卷种类 五.在容器中使用存储卷 1.只声明容器路径 [root@localhost docker]# docker run ...

  7. 5.Docker存储卷

    一.概述 1.Docker底层存储机制 Docker镜像由多个只读层叠加而成,启动容器时,Docker会加载只读镜像层并在镜像栈顶部添加一个读写层. 如果运行中的容器修改了现有的一个已经存在的文件,那 ...

  8. Docker系列03—Docker 存储卷

    一.存储卷介绍 1.1 背景 Docker 的 AFUS 分层文件系统 docker镜像由多个只读层叠加而成,启动容器时,docker会加载只读镜像层并在镜像栈顶部加一个读写层: 如果运行的容器修改了 ...

  9. 你必须知道的Docker数据卷(Volume)

    本篇已加入<.NET Core on K8S学习实践系列文章索引>,可以点击查看更多容器化技术相关系列文章. 一.将Docker数据挂载到容器 在Docker中,要想实现数据的持久化(所谓 ...

随机推荐

  1. weblogic启动节点服务java.lang.ClassCastException:com.octestring.vde.backend.BackendRoot cannot be cast to com.octestring.vde.backend.standard.BackendStandard类型转换异常

    weblogic启动节点服务器报错,java.lang.ClassCastException:com.octestring.vde.backend.BackendRoot cannot be cast ...

  2. 更换国内pip

    pip国内的一些镜像 原始地址:https://pypi.python.org/simple 国内地址: 阿里云 http://mirrors.aliyun.com/pypi/simple/ 中国科技 ...

  3. git配置:本地仓库提交到远程仓库

    前提:1.已安装git 一:创建公钥,一台机子匹配一个公钥 桌面右键选择 Git Bash Here 打开命令行输入:ssh-keygen -t rsa -C "xxx@xxx.com&qu ...

  4. 简单使用vue-cli

    上一篇我们简单的看了看vue的基本用法,就是三步,首先就是用<script>标签引入vue的依赖,然后就是写html标签,在标签中用vue指令绑定一些属性,最后就是new Vue(xxx) ...

  5. c#实现两个窗体相互传值

    本文转自:https://mp.csdn.net/postedit/100058721 1.功能展示 有时需要将子界面的内容传递到父界面,方法有好几种.经常用的是通过委托实现.具体的效果如下: ​   ...

  6. Fiddler常用设置

    1.设置抓取HTTPS请求 勾选后弹窗添加证书确认框 点击yes后,弹出警告 点击是,成功添加证书 点击OK确认,设置成功了 成功抓取到HTTPS请求 2.自定义会话框,展示GET和POST请求 3. ...

  7. 请求*.html后缀无法返回json数据的问题

    在springmvc中请求*.html不可以返回json数据. 修改web.xml,添加url拦截格式.

  8. 11G-使用跨平台增量备份减少可移动表空间的停机时间 XTTS (Doc ID 1389592.1)

    11G - Reduce Transportable Tablespace Downtime using Cross Platform Incremental Backup (Doc ID 13895 ...

  9. [日常] linux设置环境变量

    比如首先在/etc/profile里面增加这几个环境变量 export PATH=$PATH:/mnt/f/ubuntu/goProject/go/binexport GOROOT=/mnt/f/ub ...

  10. Linux系统学习 九、日志、命令、身份鉴别、目录、文件查看、控制台终端、文件属性

    一.配置静态IP地址 输入ifconfig后没有配置IP地址,接下来进行手动配置. 输入以下命令进入IP配置文件进行配置   原始内容 进入vi后,输入i进入编辑状态,编辑完成后,按esc键退出编辑状 ...