验证 Swarm 数据持久性 - 每天5分钟玩转 Docker 容器技术(104)

上一节我们成功将 Rex-Ray Volume 挂载到了 Service。本节验证 Failover 时,数据不会丢失。

Scale Up

增加一个副本:

docker service update --replicas 2 my_web

运行之前我们先推测一下,理想的结果应该是:swarm 在 swarm-worker2 上启动第二个副本,同时也将挂载 volume my_web

对比一下实际的运行结果:

535.png

出现了一点复杂的状况:

  1. swarm 首先尝试在 swarm-worker2 上启动第二个副本,但在 mount volume 失败。

  2. 重试了三次都失败了。

  3. 最后在 swarm-worker1 成功启动第二个副本。

mount 失败的原因是:以 VirtualBox 为 backend 的 Rex-Ray volume 不支持同时 attach 到多个 Host。

需要注意:这实际上是 VirtualBox 的限制,而非 Rex-Ray。如果 backend 选择 Ceph RBD 就没有这个问题。

更新 Volume

更新 volume 的内容。

536.png

service 返回更新内容,数据已经同步到副本。

540.png

当前的实验环境如图所示:

538.png

Failover

现在模拟故障情况。shutdown 节点 swarm-worker1,过一会,所有副本都会迁移到 swarm-worker2

539.png
 

访问 service,以前更新的内容完整地保留了下来。

540.png

当前的实验环境如图所示:

541.png

Rex-Ray 作为 Swarm 的存储编排方案能够很好地支持跨主机 volume 管理,而且当容器在集群中迁移时 volume 也能够自动迁移。

Swarm 数据管理就讨论到这里,下一节我们学习 Service 的 Replicated Mode 和 Global Mode。

书籍:

1.《每天5分钟玩转Docker容器技术》
https://item.jd.com/16936307278.html

2.《每天5分钟玩转OpenStack》
https://item.jd.com/12086376.html

### 回答1: 每天花5分钟阅读和学习Docker PDF,可以帮助我们快速掌握Docker的基本知识和使用技巧。首先,我们可以利用这5分钟来了解Docker的概念和基本原理,如容器化技术、镜像和容器的关系等。同时,也可以学习Docker的核心功能,如映像构建、容器管理、网络配置等。通过阅读Docker PDF,我们可以了解Docker的各种命令和选项的使用方法,例如docker run、docker build等。另外,我们可以学习如何使用Docker Compose来编排和管理多个容器的应用程序,以及如何使用Docker Swarm来进行容器集群的部署和管理。此外,阅读Docker PDF还可以让我们了解到一些Docker的最佳实践和常见问题,以及如何解决这些问题。通过每天花5分钟玩转Docker PDF,我们可以不断积累对Docker的理解和掌握,提高我们的工作效率和技术水平。 ### 回答2: 每天花费5分钟玩转Docker PDF,对于对Docker有基本了解的人来说是一个很好的学习和提升技能的方式。 首先,我们可以阅读一些Docker的入门资料和教程。可以搜索并下载一些与Docker相关的PDF文档,例如《Docker入门指南》等。通过阅读这些资料,我们可以了解Docker的基本概念、使用方法以及与之相关的命令。 其次,我们可以学习Docker的一些常用命令和操作。可以找到一些包含Docker命令和操作示例的PDF文档,例如《Docker常用命令手册》等。通过学习这些命令和操作,我们可以更好地理解和掌握Docker的使用技巧,能够更高效地管理和使用容器。 此外,我们还可以学习Docker的一些高级特性和技术。有一些PDF文档专门介绍和讲解Docker的高级特性和技术,例如Docker的网络配置、数据卷的使用、镜像构建等等。通过学习这些高级特性和技术,我们可以更好地应用Docker解决实际问题,并优化我们的容器化应用。 最后,我们可以进行一些实践和实验。可以找到一些包含Docker实践和实验的PDF文档,例如一些Docker的实战项目或者案例分析。通过实践和实验,我们可以将理论知识应用到实际问题中,也可以发现和解决在实践中遇到的困难和挑战。 总结来说,每天花费5分钟阅读和学习Docker的相关PDF文档,可以帮助我们提升Docker的基础知识和技能,掌握Docker的常用命令和操作,了解Docker的高级特性和技术,并通过实践和实验运用所学知识。这样,我们可以更好地应用和管理Docker容器,为我们的工作和项目开发带来更多的便捷和效率。 ### 回答3: 每天花5分钟学习和应用Docker将是非常值得的。Docker是一种容器化技术,可以将应用程序和其所有依赖项打包在一个独立的容器中,从而实现快速部署和管理。通过学习Docker,你可以更方便地构建、发布和运行应用程序,同时提高开发效率和部署灵活性。 在5分钟的时间里,你可以阅读并理解有关Docker的一些核心概念和基本命令的PDF文档。这些内容包括容器、镜像、容器注册表、Dockerfile等。了解这些概念将帮助你更好地理解和使用Docker。 此外,你还可以学习如何在本地环境中安装Docker,并通过一些简单的命令启动容器和运行应用程序。你可以尝试使用Docker创建一个简单的Web应用,如一个Hello World页面,并通过浏览器访问它。这将帮助你快速上手并体验Docker的优势。 为了更深入地学习Docker,你可以查看更多高级的Docker功能,如网络设置、数据卷和多容器应用的部署。学习这些功能可以帮助你更好地管理和扩展应用程序。 每天花5分钟学习和应用Docker的PDF指南是非常实用的,并且你可以通过不断积累知识和实践来提高自己的技能。无论你是开发人员、测试人员还是系统管理员,掌握Docker技术都将为你的工作带来很多便利和效益。开始行动吧,每天花5分钟玩转Docker,让你的工作更加高效和充满乐趣!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值