Docker系列7:逻辑卷

1、存储卷简介
php

一、什么是存储卷(volume)nginx

  • 就将一个容器的目录和一个宿主机的目录同步起来了,就称之为volume,也就是存储卷。docker

  • 当在容器中产生数据的时候,这个数据就会直接写入到了物理磁盘,就解决了性能的问题apache

  • 使用存储卷,还实现了数据的持久存储json

  • 经过使用存储卷,还能够实现分布式bash

    image.png

二、存储卷的类型架构

  • Bind mount volume:分布式

  • Docker managed volumeide

Bind mount volume性能

  • 这种类型是指在建立容器的时候,须要同时指定容器中的挂载点和宿主机的一个目录,这样来完成挂载

Docker managed volume

  • 这种类型是在建立容器的时候,仅仅须要同指定容器中的挂载点,不须要指定宿主机中的目录就能够完成挂载。

  • 宿主机中的目录会由docker自动生成,并且是随机生成,默认:/var/lib/docker/vfs/dir/xxxx

案例1:建立一个docker管理的卷

[root@host1 ~]# docker run --name httpd1 -it --rm -v /data busybox
/ # 
/ # echo "test message">>/data/test.txt
/ #
[root@host1 ~]# docker inspect httpd1
"Mounts": [
            {
                "Type": "volume",
                "Name": "636a1967c63705161f941550edf4b0ced1584bf71087596ad61a49df4cd6ae4c",
                "Source": "/var/lib/docker/volumes/636a1967c63705161f941550edf4b0ced1584bf71087596ad61a49df4cd6ae4c/_data",
                "Destination": "/data",
                "Driver": "local",
                "Mode": "",
                "RW": true,
                "Propagation": ""
            }
        ],
[root@host1 ~]# cd /var/lib/docker/volumes/636a1967c63705161f941550edf4b0ced1584bf71087596ad61a49df4cd6ae4c/_data
[root@host1 _data]# cat test.txt 
test message
[root@host1 _data]#

案例2:建立容器,使用宿主机的/disk目录挂载到容器中

[root@host1 ~]# docker run --name httpd1 -it --rm -v /disk:/data busybox
/ # 
/ # echo "test message">/data/t.txt
/ #
[root@host1 ..]# cat /disk/t.txt 
test message
  • 宿主机上的/disk若是不存在,会自动建立

咱们在设置容器所用的存储卷的时候,还能够设置容器所用的存成卷和另外一个容器的存储卷相同

案例3:好比前面咱们作好了容器httpd1,这里咱们再作一个httpd2,让21用相同的存储卷

[root@host1 ..]# docker run --name httpd2 --rm -it --volumes-from httpd1 busybox
/ # 
/ # ls /data/
t.txt
/ #

三、基础架构容器使用举例

  • 首先咱们能够先作个容器,这个容器不须要运行,而是仅仅做为一个基础架构支撑容器

  • 新建容器的卷复制于这个容器,好比,复制三个容器出来,第一个是nginx做为反向代理,第二个是apache出来静态请求,第三个是php处理php请求:

    image.png

  • 这个基础架构支撑容器,还能够提供一个公共的名称空间,这样上面的三个容器就有了相同的IP,主机名,并且也能够基于127进行通讯了

案例:基于基础架构容器制做容器

1)先建立基础架构容器

[root@host1 ~]# docker run --name base1 -it --rm -v /disk:/data busybox

2)建立nginx容器,复制基础架构的卷,并使用基础架构名空间

[root@host1 ..]# docker run --name nginx1 \
> --network container:base1 \
> --volumes-from base1 -it nginx:1.14-alpine

过滤容器属性数据

  • docker inspect的结果是一个列表,在列表列表中是json格式的字符串

  • 若是此时要过滤数据,其格式是 docker inspect -f {xxx} b5 来实现过滤效果

  • -f后面是双{},外侧的{}是固定格式,内侧的{}表示从{}中进行过滤

  • 过滤元素的格式 -f '{{.path.item}}'

[root@host1 ..]# docker inspect httpd1 -f '{{.Id}}'
24053ef79c61400f0f8a151087bfd7c1e31e004ee9b87b8a2e64f1efd72d2b52

[root@host1 ..]# docker inspect httpd1 -f '{{.State.Status}}'
running
相关文章
相关标签/搜索