【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

相关推荐
zhaotiannuo_199815 小时前
渗透测试之docker
运维·docker·容器
王正南16 小时前
kali-linux 虚拟机连接安卓模拟器
android·linux·运维·虚拟机连接模拟器·安卓模拟器,linux虚拟机
三不原则16 小时前
故障案例:容器启动失败排查(AI运维场景)——从日志分析到根因定位
运维·人工智能·kubernetes
吳所畏惧16 小时前
Linux环境/麒麟V10SP3下离线安装Redis、修改默认密码并设置Redis开机自启动
linux·运维·服务器·redis·中间件·架构·ssh
孤岛悬城16 小时前
54 安装k8s-1.20.11
云原生·容器·kubernetes
yueguangni16 小时前
sysstat 版本 10.1.5 是 CentOS 7 的默认版本,默认情况下确实不显示 %wait 字段。需要升级到新版sysstat
linux·运维·centos
funfan051717 小时前
【运维】MySQL数据库全量备份与恢复实战指南:从入门到精通
运维·数据库·mysql
-dcr17 小时前
49.python自动化
运维·python·自动化
萧曵 丶18 小时前
Linux 业务场景常用命令详解
linux·运维·服务器
乾元18 小时前
ISP 级别的异常洪泛检测与防护——大流量事件的 AI 自动识别与响应工程
运维·网络·人工智能·安全·web安全·架构