参考视频
1.数据卷概述
1.1.数据卷的概念
数据卷的本质是宿主机中的一个目录或文件。
若容器没有配置数据卷,容器产生的数据就会存储在容器内部,当容器被删除,数据就会丢失。
若容器配置了数据卷,容器中的文件操作,本质上都是对这个数据卷进行操作(实现了目录映射);而数据卷的修改,也会导致容器的文件修改,因为容器中的数据来源于数据卷。
- 数据卷的本质是宿主机中的一个目录或文件;
- 配置数据卷,实际上是进行了目录映射,类似于共享文件,并不会产生两倍的空间占用;
- 一个数据卷可以挂载多个容器;
- 一个容器可以挂载多个数据卷。
1.2.为什么需要配置数据卷
数据卷的存在解决了以下问题:
- [容器崩溃时的数据恢复] 若没有配置数据卷,容器崩溃不得不删除,此时容器内的数据就会丢失;但配置数据卷后,删除容器时并不会删除数据卷中的内容,在创建容器时重新配置数据卷即可实现数据恢复。
- [容器与外部机器进行数据交换] 宿主机可以访问容器,但外部机器则不可以。而有了数据卷,外部机器可以访问宿主机,并对宿主机的数据卷进行修改,从而实现了容器与外部机器的数据交换。
- [容器与容器之间进行数据交换] 容器之间是相互隔离的,如果容器A希望修改容器B的数据,可以修改容器B的数据卷,从而达到目的。
2.配置数据卷
在运行镜像创建容器实例时,使用-v参数设置数据卷
docker run -v <宿主机数据卷目录(文件)>:<容器内目录(文件)> <参数>...
示例:运行mysql5.6镜像以创建一个名为"container_mysql"的交互式容器实例,并为其配置数据卷
# 数据卷目录:/root/docker_container/container_mysql
# 容器目录:/root/data
docker run -it --name=container_mysql -v /root/docker_container/container_mysql:/root/data mysql:5.6 /bin/bash
为容器配置数据卷后,在挂载的容器目录中创建文件,该文件将会被同步到数据卷中(准确地说,是创建到数据卷中。而挂载的容器检测到数据卷中新增了一个文件),反之亦然。