前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker的持久化存储和数据共享(四)

Docker的持久化存储和数据共享(四)

作者头像
蒋老湿
修改2019-12-09 14:35:01
2K0
修改2019-12-09 14:35:01
举报
文章被收录于专栏:技术栈技术栈

有些容器会自动产生一些数据,为了不让数据随着container的消失而消失,保证数据的安全性。例如:数据库容器,数据表的表会产生一些数据,如果我把container给删除,数据就丢失。为了保证数据不丢失,这就有了Volume的存在。

Data Volume 结构图

Docker持久化数据的方案

  • 基于本地文件系统的Volume。可以再执行Docker create或Docker run时,通过-v参数将主机的目录作为容器的数据卷。这部分功能便是基本的本地文件系统的volume管理。
  • 基于plugin的Volume,支持第三方的存储方案,比如NAS,aws

Volume的类型

  • 受管理的data Volume,由docker后台自动创建。
  • 绑定挂载的Volume,具体挂载位置可以由用户指定。

数据持久化之Data Volume

以官方镜像mysql的dockerfile文件为例。其中dockerfile通过volume指定了当前容器中要备份的文件路径,但是并没有指定说要保存到宿主机的哪个位置。

volume: 映射容器中的文件到本地宿主机硬盘中

在我们使用docker run 启动mysql镜像容器的时候,容器会默认在宿主机生成一个volume,至于位置在哪,名字是什么,可以通过如下命令查看

代码语言:txt
复制
#查看所有volume
docker volume ls
#删除指定volume
docker volume rm [volume name]
#查看volume详细
docker volume inspect [volume name]

此时我们删除容器,发现volume数据卷还在,有保留。

此时我们会觉得这个data volume name 的名字很长,很不好理解。我们可以通过-v如下命令来指定生成的volume name docker run -d -v mysql:/var/lib/mysql --name mysql mysql5.7

-v:前参数是volume name, :后面的是要备份的文件目录(容器)

此时我们删除容器,volume数据卷还在,我们用这个名为mysql的volume作为一个新容器的数据卷,覆盖它。

docker run -d -v mysql:/var/lib/mysql --name mysql2 mysql5.7

进入mysql2容器中,mysql -uroot 进入数据库中,发现当前数据库数据和之前删除的容器中的数据库数据一样。

数据持久化之bind Mounting

和上面Data Volume不同的是,bind Mounting只能通过**docker run -v**方式启动,无法使用dockerfile文件的方式。

运行容器的时候指定本地的一个文件目录和容器中的一个文件目录的映射,通过这个可以做文件数据同步,2方无论哪一方有修改,另一方都会同步内容

代码语言:txt
复制
docker run -d -v $(pwd):/usr/share/nginx/html -p 80:80 --name nginx nginx

这个时候-v:前面的参数是本机文件路径, :后面是docker文件目录(容器)

值得注意的是,使用bind Mounting方式做数据卷的映射时,首次docker run -v 运行,如果本机的文件夹是没有内容的,docker容器中的文件夹是有内容的,则本机的会覆盖dokcer容器中的,也就是容器中原本有内容的也会没有内容。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018年08月11日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 数据持久化之Data Volume
  • 数据持久化之bind Mounting
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档