Docker19_Docker 容器的数据卷3

一、数据卷概念及作用

 思考:

  • Docker 容器删除后,在容器中产生的数据还在吗?  -不在了

  

 思考:

  • Docker 容器和外部机器可以直接交换文件吗?  -不能,外部机器跟容器之间网络不互通,但是跟宿主机之间是互通的

  

 思考:

  • 容器之间想要进行数据交互?

  

 数据卷

  • 数据卷是宿主机中的一个目录或文件
  • 当容器目录和数据卷目录绑定后,对方的修改会立即同步(容器目录和宿主机中的目录挂载起来,这时宿主机的目录就被称为数据卷)
  • 一个数据卷可以被多个容器同时挂载
  • 一个容器也可以挂载多个数据卷

 数据卷作用

  • 容器数据持久化
  • 外部机器和容器间接通信
  • 容器之间数据交换

二、配置数据卷

  • 创建启动容器时,使用 –v 参数 设置数据卷
docker run ... –v 宿主机目录(文件):容器内目录(文件) ... 
例如:docker run -it --name=c1 -v /root/data:/root/data_container centos:7 /bin/bash
  • 注意事项:

    1. 目录必须是绝对路径
    2. 如果目录不存在,会自动创建
    3. 可以挂载多个数据卷

  • 演示  

  

  

  

  

  

 一个容器挂载多个数据卷:

  

  多个容器挂载同一个数据卷,实现容器间的数据交换:

  即同一个数据卷挂载到不同的容器上,间接的实现容器间的数据交换:

   

   

   

   

三、配置数据卷容器

 1、数据卷容器

  多容器进行数据交换的方式:
    1. 多个容器挂载同一个数据卷
    2. 数据卷容器

     

    c3数据卷容器挂载数据卷,c1和c2容器分别挂载到c3数据卷容器上,这样就相当于c1和c2挂载到了数据卷上,即c1、c2、c3都挂载到了同一个数据卷上,也就意味着c1、c2、c3可以相互进行数据的传输通信了。即使c3容器出问题,c1和c2仍旧可以进行通信。

 2、配置数据卷容器

  1. 创建启动c3数据卷容器,使用 –v 参数设置数据卷,这是容器目录,会在宿主机上自动分配一个目录

docker run –it --name=c3 –v /volume centos:7 /bin/bash 

  2. 创建启动 c1 c2 容器,使用 –-volumes-from 参数挂载数据卷容器

docker run –it --name=c1 --volumes-from c3 centos:7 /bin/bash

docker run –it --name=c2 --volumes-from c3 centos:7 /bin/bash  

 

  

  

 

    

  

    

    

四、数据卷小结

 1. 数据卷概念

  • 宿主机的一个目录或文件

 2. 数据卷作用

  • 容器数据持久化
  • 客户端和容器数据交换
  • 容器间数据交换

 3. 数据卷容器

  • 创建一个容器,挂载一个目录,让其他容器继承自该容器( --volume-from )。
  • 通过简单方式实现数据卷配置

 

posted on 2024-05-28 16:44  花溪月影  阅读(3)  评论(0编辑  收藏  举报