数据存储剖析卷与持久化底层原理海量资源.pdfVIP

数据存储剖析卷与持久化底层原理海量资源.pdf

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

本文由简悦SimpRead转码,原文地址

上一我介绍了Docker网络实现,为我们的容器插上了网线。这一我将介绍Docker的卷,为

我们的容器插上磁盘,实现容器数据的持久化。

为什么容器需要持久化

容器按照业务类型,总体可以分为两类:

无状态的(数据不需要被持久化)

有状态的(数据需要被持久化)

显然,容器更擅长无状态应用。因为未持久化数据的容器根的生命周期与容器的生命周期一样,容

器文件系统的本质是在镜像层上面创建的读写层,运行中的容器对任何文件的修改都存在于该读写层,

当容器被删除时,容器中的读写层也会随之。

虽然容器希望所有的业务都尽量保持无状态,这样容器就可以开箱即用,并且可以任意调度,但实际业

务总是有各种需要数据持久化的场景,比如MySQL、Kafka等有状态的业务。因此为了解决有状态业

务的需求,Docker提出了卷(Volume)的概念。

什么是卷?卷的本质是文件或者,它可以绕过默认的联合文件系统,直接以文件或的形式存在

于宿主机上。卷的概念不仅解决了数据持久化的问题,还解决了容器间共享数据的问题。使用卷可以将

容器内的或文件持久化,当容器重启后保证数据不丢失,例如我们可以使用卷将MySQL的持

久化,实现容器重启数据库数据不丢失。

Docker提供了卷(Volume)的功能,使用dockervolume命令可以实现对卷的创建、查看和删除等

操作。下面我们来详细了解一下这些命令。

Docker卷的操作

创建数据卷

使用dockervolumecreate命令可以创建一个数据卷。

我们使用以下命令创建一个名为myvolume的数据卷:

$dockervolumecreatemyvolume

在这里要说明下,默认情况下,Docker创建的数据卷为local模式,仅能提供本主机的容器。如

果想要实现,需要借助网络来实现。Docker的local模式并未提供管理,因此在

生产环境中需要手动磁盘空间。

除了使用dockervolumecreate的方式创建卷,我们还可以在Docker启动时使用-v的方式指定容

器内需要被持久化的路径,Docker会自动为我们创建卷,并且绑定到容器中,使用命令如下:

$dockerrun-d--name=nginx-volume-v/usr/share/nginx/htmlnginx

使用以上命令,我们启动了一个nginx容器,-v参数使得Docker自动生成一个卷并且绑定到容器的

/usr/share/nginx/html中。

我们可以使用dockervolumels命令来查看下主机上的卷:

$dockervolumels

DRIVERVOLUMENAME

local

eaa8a223eb61a2091bf5cd5247c1b28ac287450a086d6eee9632d9d1b9f69171

可以看到,Docker自动为我们创建了一个名称为随机ID的卷。

查看数据卷

已经创建的数据卷可以使用dockervolumels命令查看。

$dockervolumels

DRIVERVOLUMENAME

localmyvolume

通过输出可以看到myvolume卷已经创建成功。

如果想要查看某个数据卷的详细信息,可以使用dockervolumeinspect命令。例如,查看

myvolume的详细信息,命令如下:

$dockervolumeinspectmyvolume

{

CreatedAt:2020-09-08T09:10:50Z,

Driver:local,

Labels:{},

Mountpoint:/var/lib/docker/volumes/myvolume/_data,

Name:myvolume,

Option

您可能关注的文档

文档评论(0)

187****2251 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档