『现学现忘』Docker基础 — 28、Docker容器数据卷介绍
1、什么是Docker容器数据卷
Docker容器数据卷,即Docker Volume(卷)。
当Docker容器运行的时候,会产生一系列的数据文件,这些数据文件会在关闭Docker容器时,直接消失的。但是其中产生部分的数据内容,我们是希望能够把它给保存起来,另作它用的。
所以我们期望:
- 将应用与运行的环境打包形成容器运行,伴随着容器运行产生的数据,我们希望这些数据能够持久化。
- 希望容器之间也能够实现数据的共享。
根据我们之前所学,Docker容器产生的数据,如果不通过docker commit命令生成新的镜像,把数据做为镜像的一部分保存下来。那么当容器删除后,数据自然也就没有了。但为了能保存Docker容器中的数据,Docker为我们提供了卷技术(Volume)。
总结:Docker容器中产生的数据,同步到本地,这就是卷技术。也就是通过目录的挂载,将容器内的目录,挂载到Linux系统上面,实现容器数据的持久化。
2、数据卷的作用
数据卷就是目录或文件,存在于一个或多个容器中,由Docker挂载到容器,但不属于联合文件系统,因此能够绕过Union File System(联合文件系统),提供一些用于持续存储或共享数据的特性。
数据卷的设计目的就是为了Doeker容器中数据的持久化,完全独立于容器的生存周期,Docker不会在容器删除时,删除其挂载的数据卷。
数据卷:
- 数据卷可在容器之间共享或重用数据。
- 数据卷中的更改可以直接生效。
- 数据卷中的更改不会包含在镜像的更新中。
- 数据卷的生命周期一直持续到没有容器使用它为止。
3、数据卷的使用
使用-v参数给容器添加数据卷,Volume(卷)的首字母。
我们以CentOS容器为例进行演示。
步骤1:下载CentOS镜像。
# docker pull centos
[root@192 ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
centos latest 300e315adb2f 3 months ago 209MB
步骤2:启动CentOS镜像,并挂载数据卷。
命令:docker run -it -v /宿主机绝对路径目录:/容器内目录 镜像名或镜像ID
我们希望宿主机/home中的HostDataVolume目录和容器中/home中的ContainerDataVolume目录实现数据卷挂载。
我们先来查看宿主机/home目录的内容,如下:
[root@192 ~]# ll /home/
总用量 0
没有任何文件。
执行启动CentOS容器命令:
# 启动centos容器
[root@192 ~]# docker run -it -v /home/HostDataVolume:/home/ContainerDataVolume centos /bin/bash
# 查看centos容器中/home目录中内容
[root@5f63a0fc88c5 /]# ls /home/
ContainerDataVolume
# 我们可以看到在centos容器的/home目录里,有ContainerDataVolume目录
# 这个目录肯定是容器启动后,根据
# -v /home/HostDataVolume:/home/ContainerDataVolume创建的。
我们在来看看宿主机上/home目录的内容,如下:
[root@192 ~]# ls /home/
HostDataVolume
发现生成了HostDataVolume文件夹,说明我们数据卷的挂着初步成功。
提示:挂载的文件夹可以存在也可以不存在,不存在则会自动创建。
步骤3:验证CentOS容器数据卷是否挂着成功。
我们可以使用docker inspect命令,来查看CentOS容器的详细数据。
[root@192 ~]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS
5f63a0fc88c5 centos "/bin/bash" 10 minutes ago Up 10 minutes
# 查看centos容器的详细数据
[root@192 ~]# docker inspect 5f63a0fc88c5
[
{
"Id": "5f63a0fc88c5ef2804a45dff0fbf82ae153f2df04887427a3057668867d64443",
"Created": "2021-03-18T11:35:14.632025511Z",
... # 省略
... # 省略
"HostConfig": { # 主机配置
"Binds": [
"/home/HostDataVolume:/home/ContainerDataVolume"
],
... # 省略
},
... # 省略
"Mounts": [ # 容器挂载的数据卷
{
"Type": "bind",
"Source": "/home/HostDataVolume", # 宿主机内地址
"Destination": "/home/ContainerDataVolume", # Docker容器内的地址
"Mode": "", # 两目录就好比同一个目录。
"RW": true, # 支持读写操作
"Propagation": "rprivate"
}
],
"Config": {
... # 省略
# 新版的Dodker把Volumes信息放到了Mounts的Json字待串里了
"Volumes": null,
... # 省略
}
... # 省略
}
]
[root@192 ~]#
看到上面的信息,主要是Mounts属性,说明数据卷挂载已经成功。
『现学现忘』Docker基础 — 28、Docker容器数据卷介绍的更多相关文章
- Docker(六)容器数据卷
容器数据卷 docker的理念回顾 将应用和环境打包成一个镜像 需求:数据可以持久化和同步 使用数据卷 指定路径挂载 docker run -it -v 主机目录:容器内目录 # 测试 [root@h ...
- Docker容器数据卷介绍和命令
是什么 一句话:有点类似我们Redis里面的rdb和aof文件 先来看看Docker的理念: * 将运用与运行的环境打包形成容器运行 ,运行可以伴随着容器,但是我们对数据的要求希望是持久化的 * ...
- 『现学现忘』Docker基础 — 32、通过DockerFile的方式挂载数据卷
目录 1.简单了解一下DockerFile 2.通过DockerFile的方式挂载数据卷 (1)创建DockerFile文件 (2)编辑Dockerfile文件 (3)构建Dokcer镜像 (4)启动 ...
- 『现学现忘』Docker基础 — 34、DockerFile文件详解
目录 1.DockerFile文件说明 2.Dockerfile构建过程解析 (1)Docker容器构建三步骤 (2)Dockerfile文件的基本结构 (3)Dockerfile注意事项 (4)Do ...
- 『现学现忘』Docker基础 — 30、Docker中数据卷相关命令
目录 1.Volume命令说明 2.Volume命令的使用 (1)创建数据卷 (2)查看本地数据卷列表 (3)打印myVolume数据卷的详细信息 (4)删除数据卷 (5)删除所有未使用的数据卷 3. ...
- 『现学现忘』Docker基础 — 31、实现MySQL同步数据
目录 1.搜索镜像 2.拉取镜像 3.查看镜像 4.启动镜像 5.操作容器 (1)在MySQL中创建数据库 (2)外部连接Dokcer容器中的MySQL服务 (3)查看挂载情况 (4)测试MySQL服 ...
- 『现学现忘』Docker基础 — 33、Docker数据卷容器的说明与共享数据原理
目录 1.数据卷容器的说明 2.数据卷容器共享数据原理 3.总结 4.练习:MySQL实现数据共享 1.数据卷容器的说明 (1)什么是数据卷容器 一个容器中已经创建好的数据卷,其它容器通过这个容器实现 ...
- Docker 基础概念科普 和 常用操作介绍
Docker 基础概念 Docker是什么? Docker的思想来自于集装箱,集装箱解决了:在一艘大船上,可以把货物规整的摆放起来.并且各种各样的货物被集装箱标准化了,集装箱和集装箱之 ...
- docker 12 docker容器数据卷
数据卷概念 ♣我们知道,当我们把一个运行中的容器关闭后,容器里的数据就没有了(如果你做了docker commit操作,数据会保留到新的镜像里面).所以我们就需要用容器数据卷把容器数据进行持久化储存. ...
随机推荐
- 扩展NSDate类实现快捷使用 —— 昉
获取当前日期和时间: +(NSDate *)getCurrentDate{ NSDate *now = [NSDate date]; return now; } 将日期转换为字符串: +(NSStri ...
- 框架3.1--V·P·N简介
目录 框架3.1-VPN简介 1.晨考 2.昨日问题 3.今日内容 4.vpn的简介 5.VPN的作用 6.VPN的种类 7.介绍OpenVPN 框架3.1-VPN简介 1.晨考 1.画iptable ...
- 使用Sinopia部署私有npm仓库
使用Sinopia部署私有npm仓库 [root@localhost ~]# hostnamectl set-hostname --static npm-server [root@npm-server ...
- 手写一个springboot starter
springboot的starter的作用就是自动装配.将配置类自动装配好放入ioc容器里.作为一个组件,提供给springboot的程序使用. 今天手写一个starter.功能很简单,调用start ...
- 乘风破浪,遇见未来元宇宙(Metaverse)之进入元宇宙世界,虚拟数字人行业洞察报告
正值元宇宙热潮,虚拟数字人兴起 作为⼀个新兴领域,虚拟数字⼈已经引起市场和资本的⾼度关注,截⾄目前据不完全统计,全球范围已有500+虚拟数字人相关项目获得融资,融资总额超10亿美元,并且融资项目和总额 ...
- TensorFlow 关闭日志打印
ubuntu 中打开命令行,执行如下指令 vim ~/.bashrc 进入配置文件后在文件末尾加上: export TF_CPP_MIN_LOG_LEVEL=2 保存退出,再使用下面命令使刚才修改的配 ...
- EXCEL应用之商机分析:企业商机分析模板免费用
一.分析背景 商机是订单的来源,因此抓住每个销售机会,就可以更多地赢得交易.商机管理可以说是业务环节中最为关键的一步.每个企业都有自己的商机阶段划分,从销售人员接触客户.发现商机.跟进商机.推进销售 ...
- 帆软思迈特软件Smartbi两家区别在哪里?
简单介绍下,从前端展现市场来看,国内这几年帆软算是做的比较好的一家公司,整体市场营销,以及产品易用性也是不错.思迈特公司也是一家专门从事做数据分析平台的公司,也有接近20年的历史,早期从银行.金融证券 ...
- shell脚本编程练习
转至:http://www.178linux.com/88406 1.写一个脚本,使用ping命令探测172.16.250.1-172.16.250.254之间的所有主机的在线状态 在线的主机使用绿色 ...
- centos7 部署ansible
Ansible默认采用SSH的方式管理客户端,基于python开发,由paramiko和PyYAMl 两个关键模块构建 支持非root用户管理,支持sudo ansible作用:通过使用ansible ...