当前位置: 首页 > news >正文

【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 

 

 

http://www.lryc.cn/news/98943.html

相关文章:

  • CentOS7安装jenkins
  • Hadoop的伪分布式安装方法
  • iOS 应用上架的步骤和工具简介
  • 【信号去噪】基于马氏距离和EDF统计(IEE-TSP)的基于小波的多元信号去噪方法研究(Matlab代码实现)
  • 智驾SOC shell编程应用实战笔记
  • C#实现计算题验证码
  • 【lesson6】Linux下:第一个小程序,进度条代码
  • PostgreSQL实战-pg13主从复制切换测试
  • 如何使用OpenCV库进行图像检测
  • Mybatis中where 1=1 浅析
  • element中el-input组件限制输入条件(数字、特殊字符)
  • 会议OA项目之会议发布(一)
  • 【Android】对象为null的一个原因:在方法内部,重新创建了一个新的对象并将其赋值给原对象,但这并不会改变原始的原对象的引用
  • macbook 软件iMovie for Mac(专业视频剪辑工具)中文版
  • web APIs-练习一
  • AX88179A千兆网卡芯片,支持switch联网
  • Pytorch个人学习记录总结 05
  • windows部署安装redis安装教程
  • Jmeter post请求传参问题
  • 对Windows应用程序进行代码签名
  • 2022 China Open Source Report
  • postgresql|数据库|启动数据库时报错:FATAL: could not map anonymous shared memory的解决
  • 数字签名与数字证书
  • 基于Jquery EasyUI JSZip FileSaver的简单使用
  • git远程一个分支对应本地两个分支推送
  • SpringCloud学习—Hystrix:服务熔断
  • 8款常用系统镜像烧录软件
  • 设计模式什么情况下适合使用呢?
  • Docker和K8s区别,使用场景,具体怎么使用以及详细命令
  • K8S集群创建和管理,以及常用命令