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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了验证 Swarm 数据持久性 - 每天5分钟玩转 Docker 容器技术(104)相关的知识,希望对你有一定的参考价值。

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

Scale Up

增加一个副本:

docker?service?update?--replicas?2?my_web

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

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

技术分享图片

出现了一点复杂的状况:

  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 的内容。

技术分享图片

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

技术分享图片

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

技术分享图片

Failover

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

技术分享图片

?

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

技术分享图片

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

技术分享图片

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

技术分享图片

以上是关于验证 Swarm 数据持久性 - 每天5分钟玩转 Docker 容器技术(104)的主要内容,如果未能解决你的问题,请参考以下文章

Swarm 如何存储数据?- 每天5分钟玩转 Docker 容器技术(103)

Swarm 如何存储数据?- 每天5分钟玩转 Docker 容器技术(103)

如何创建 Swarm 集群?- 每天5分钟玩转 Docker 容器技术(95)

Swarm 如何实现 Failover?- 每天5分钟玩转 Docker 容器技术(98)

Docker Swarm 中最重要的概念- 每天5分钟玩转 Docker 容器技术(94)

如何访问 Service?- 每天5分钟玩转 Docker 容器技术(99)