Docker容器的持久存储模式

简介: 本文讲的是Docker容器的持久存储模式,【编者的话】本文讨论了Docker容器的持久存储模式,包括默认模式、数据卷模式、只含数据的容器、从主机映射而得的数据卷、从主机映射而得的数据卷且存储后端是共享存储以及 Convoy 存储插件,其中第 2-4 种支持容器持久性,即升级容器也不会移除数据;第 5-6 种支持主机持久性,即主机失效也不会引起数据丢失。
本文讲的是Docker容器的持久存储模式 【编者的话】本文讨论了Docker容器的持久存储模式,包括默认模式、数据卷模式、只含数据的容器、从主机映射而得的数据卷、从主机映射而得的数据卷且存储后端是共享存储以及 Convoy 存储插件,其中第 2-4 种支持容器持久性,即升级容器也不会移除数据;第 5-6 种支持主机持久性,即主机失效也不会引起数据丢失。

简介

说到Docker,持久存储是一个需要小心处理的问题。通常一个服务的升级流程是关停旧版本容器,然后拉取并启动新版本容器。默认情况下,旧版容器包含的所有数据都会被消除,我们当然不想这样。

dockerdatapatterns-container_service_upgrade.jpg


本文将讨论保证数据持久性的几种模式:
  • 默认模式:不支持任何持久性
  • 数据卷:容器持久性
  • 仅含数据的容器:容器持久性
  • 从主机映射而得的卷:容器持久性
  • 从主机映射而得的卷,存储后端是共享存储:主机持久性
  • Convoy 卷插件:主机持久性

上述几种持久性(我自己发明的)是什么意思呢?
  • 容器持久性:升级容器并不会移除数据
  • 主机持久性:主机失效也不会引起数据丢失

下面一一解释这些持久存储模式。

默认模式

这是最基本的一种持久存储模式。创建容器时没有指定任何与卷相关的选项,数据保存在容器内部。前文已经提及,升级容器会导致容器数据丢失。如果容器是无状态的,这当然没问题;如果容器是有状态的,需要持久保存数据(例如,数据库容器),默认模式显然就不适合了。

dockerdatapatterns-container_only.jpg


数据卷

在创建容器时指定  volume  选项。数据卷位于主机系统的特定位置下(例如, /var/lib/docker/volumes/_container_name_/_data 目录下,可用  docker inspect  命令查看),升级容器时不会改动这些数据。

dockerdatapatterns-volume_only.jpg


只包含数据的容器

只包含数据的容器 与典型的数据卷相比略有不同。首先创建一个数据卷容器(通常以 busybox 或 alpine 为基础镜像),然后在启动主容器时使用  -volumes-from  选项,把数据卷容器的所有卷映射到主容器内。这是一种典型的 随从 模式实现。

dockerdatapatterns-volumes_from_data_container.jpg


从主机映射而得的数据卷

这种模式是把主机的目录映射为容器的数据卷。在数据卷模式中,容器的文件夹实际上保存在主机 /var/lib/docker/volumes/ 目录下面的一个文件。而 从主机映射的卷 是直接建立容器与主机之间的目录映射。这种方式与数据卷模式具有相同的优点,也可以混合使用这两种模式。这种模式的主要缺点是容器与主机之间的权限(uid/gid)映射。

dockerdatapatterns-host_mapping.jpg


从主机映射而得的数据卷,存储后端是共享存储

把共享存储(例如, NFS, Gluster ...)的文件夹映射为主机的文件夹,再映射为容器的卷。这种模式的主要优点是:即使主机失效,容器的数据也不会丢失。

dockerdatapatterns-shared_storage_host_mapping.jpg


Convoy 卷插件

主机级别的持久存储映射感觉还是有些“静态”——你必须保证所有主机默认具有相同的文件夹结构,否则终有一天会遇上麻烦。

Convoy  是 docker 的一个存储卷插件,起一个中介容器的作用:确保容器的数据卷链接到共享存储,目前实现了 NFS 和 Gluster 两种共享存储的支持,其他共享存储的支持据说“即将”实现。

dockerdatapatterns-convoy.jpg


其他模式

还有很多其他的持久存储模式。如果你有独特的持久存储模式,告诉我一声!

Flocker

我知道  Flocker  ,虽然没试用过,看起来挺不错的。

diagram-1.jpg


结论

  • Docker 支持数据持久性!
  • 记住有多种持久存储模式,每一种各有利弊。
  • 专业诀窍:一定要测试你选择的持久模式!与自我修复(resilience)和性能相关的方方面面都要进行复核。

原文链接:Docker : Storage Patterns for Persistence (翻译:柳泉波)

原文发布时间为: 2016-05-09 
本文作者:bnuhero 
本文来自云栖社区合作伙伴DockerOne,了解相关信息可以关注DockerOne。
原文标题:Docker容器的持久存储模式
目录
相关文章
|
7月前
|
Kubernetes Devops Docker
Kubernetes 和 Docker Swarm:现代 DevOps 的理想容器编排工具
本指南深入解析 Kubernetes 与 Docker Swarm 两大主流容器编排工具,涵盖安装、架构、网络、监控等核心维度,助您根据团队能力与业务需求精准选型,把握云原生时代的技术主动权。
655 115
|
6月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
705 51
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
6月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
721 6
|
6月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
606 6
|
6月前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
895 4
|
8月前
|
Kubernetes Docker Python
Docker 与 Kubernetes 容器化部署核心技术及企业级应用实践全方案解析
本文详解Docker与Kubernetes容器化技术,涵盖概念原理、环境搭建、镜像构建、应用部署及监控扩展,助你掌握企业级容器化方案,提升应用开发与运维效率。
1132 108
|
9月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
671 57