【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

相关推荐
三十..3 分钟前
Redis 核心原理与高可用架构实践
运维·数据库·redis
我是谁??2 小时前
ubuntu22.04 通过docker部署vLLM(Qwen3-0.6B)大模型+New API+OpenWebUI
docker·容器·vllm
jinglong.zha2 小时前
LScript-从零基础到商业变现的AI自动化学习平台
运维·学习·自动化
运维瓦工2 小时前
DevOps 生态介绍(十):Docker Compose 核心 YAML 配置详解与常用命令大全
spring cloud·docker·容器
Adorable老犀牛2 小时前
Telegraf:InfluxData 出品的指标采集代理
运维·telegraf
云烟成雨TD3 小时前
Spring AI 1.x 系列【59】容器化开发支持:Docker Compose 与 Testcontainers
人工智能·spring·docker
北塔软件3 小时前
北塔软件智能体平台 | 不只监控,更是AI时代的数据资产
运维·人工智能·知识库·北塔软件
Plastic garden3 小时前
K8s(10)NFS 的动态 PV 创建数据库给k8s的mysql和redis
docker·容器·kubernetes
AOwhisky3 小时前
学习自测与解析:MySQL第五、六、七期核心知识点详解
运维·数据库·笔记·学习·mysql·云计算
与海boy3 小时前
docker compose minio
docker·容器·eureka