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 )。
- 通过简单方式实现数据卷配置