【Docker】容器的数据卷

目录

一、数据卷的概念与作用

二、数据卷的配置

三、数据卷容器的配置


一、数据卷的概念与作用

在了解什么是数据卷之前我们先来思考以下这些问题:

1.如果我们一个容器在使用后被删除,那么他里面的数据是否也会丢失呢?比如容器内的MySQL的数据,在删除后是否还存在?不存在,怎样做数据持久化呢?

2.容器内部能否直接和外部机器进行通信呢?不能的话怎样才可以呢?

3.容器之间进行数据交换,应该怎么做呢?

以上问题我们都可以使用数据卷实现,那么回到数据卷的概念,什么是数据卷呢,数据卷其实就是宿主机里的一个文件或目录,当容器内部指定目录与该目录绑定后,双方修改其内容会立马进行同步。

一个容器可以挂载多个数据卷,同样一个数据卷也可以绑定多个容器。

那么上述三个问题就可以解决,当我们在创建容器时进行挂载数据卷后,容器中可以将数据存在指定目录后,一旦进行修改则同步给宿主机的指定目录,这样可以做到数据持久化。我们也可以通过挂载数据卷来实现容器与外部机器的通信,当外部机器与宿主机通信改变数据卷内容时,也同样会同步给容器。当然可以将同一个数据卷绑定多个容器来实现容器间的数据交互。

总结:数据卷就是宿主机上的一个目录或文件

二、数据卷的配置

我们在创建容器时可以通过-v 命令来挂载容器卷

docker run -id --name=name -v 宿主机绝对路径:容器绝对路径 镜像:版本

要注意的是上面-v后的两个路径必须是绝对路径

如果路径不存在,则会自动创建

可以通过-v挂载多个数据卷

比如:

docker run -id --name=name -v /root/data:/etc/nginx/nginx.conf -v /root/test:/etc/test centos:7

三、数据卷容器的配置

在进行数据卷容器配置前我们首先需要了解以下什么是数据卷容器?

当多个容器之间想要进行数据交互时,我们可以先让一个容器挂载一个数据卷,然后再将需要进行交互的多个容器挂载到这个挂载了数据卷的容器上,这样就可以进行交互,那么这个先挂载数据卷的容器就叫做数据卷容器

在进行配置时首先我们需要先创建一个容器,挂载数据卷

docker run -id --name=c3 -v /root/data:/volume centos:7

然后我们可以通过-volumes-from来配置

docker run -id --name=c1 -volumes-from c3 centos:7

docker run -id --name=c2 -volumes-from c3 centos:7

相关推荐
北京阿法龙科技有限公司2 小时前
AR眼镜基于上下文智能识别:电力运维高效规范操作应用方案|阿法龙XR云平台
运维·ar·xr
RisunJan2 小时前
docker一键部署项目
运维·docker·容器
你的人类朋友2 小时前
😎 Node.js 应用多阶段构建 Dockerfile 详解
后端·docker·容器
victory04313 小时前
K8S NFS 静态配置和动态配置 StorageClass
云原生·容器·kubernetes
运维 小白3 小时前
k8s 部署NFS和动态供应器
云原生·容器·kubernetes
luyun0202023 小时前
Windows 11操作更丝滑,绝了
java·运维·figma
wanhengidc4 小时前
全面了解云手机的安全性
运维·服务器·游戏·智能手机·云计算
hweiyu004 小时前
Docker(K8S)容器架构教程(视频教程)
docker·架构·kubernetes
menge23334 小时前
Linux DNS域名解析服务器练习
linux·运维·服务器
努力成为一个程序猿.5 小时前
Clickhouse数据副本和分片
运维·clickhouse·debian