【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

相关推荐
信创工程师-小杨10 小时前
Linux内网环境如何解决依赖的问题
linux·运维·服务器
java知路10 小时前
linux yum 下载docker安装包及依赖安装包,并离线安装
linux·运维·docker
2601_9555052510 小时前
自然人身份确权可信基础设施赋能 DID 身份合规
运维·金融·区块链·健康医疗·智能硬件·教育电商·政务
没有退路那我就不要散步11 小时前
kube-proxy优化
docker·容器·kubernetes
難釋懷11 小时前
Nginx-KeepAlive
运维·nginx
2601_9564141411 小时前
迈向智慧实验室:金现代的全链路质量管控与自动化解决方案
运维·自动化
YJlio11 小时前
《Sysinternals实战指南》16.5 Ctrl2Cap 工具详解:把 Caps Lock 变成 Ctrl 的键盘改造与回退方法
linux·运维·服务器·网络·python·学习·计算机外设
ai产品老杨12 小时前
解耦安防碎片化:基于 Docker 与边缘计算的 AI 视频管理平台架构演进(附 GB28181/RTSP 统一接入与源码交付实践)
人工智能·docker·边缘计算
王二端茶倒水12 小时前
智慧小区宽带无线运营:从网络交付到认证、计费与运维闭环
运维·物联网·架构
旅僧12 小时前
远程终端工具安装
运维