您的位置:首页 > 运维架构 > Docker

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

2017-12-11 07:22 831 查看
上一节我们成功将 Rex-Ray Volume 挂载到了 Service。本节验证 Failover 时,数据不会丢失。[b]Scale Up[/b]增加一个副本:
docker service update --replicas 2 my_web
运行之前我们先推测一下,理想的结果应该是:swarm 在
swarm-worker2
上启动第二个副本,同时也将挂载 volume
my_web
。对比一下实际的运行结果:

出现了一点复杂的状况:swarm 首先尝试在
swarm-worker2
上启动第二个副本,但在 mount volume 失败。
重试了三次都失败了。
最后在
swarm-worker1
成功启动第二个副本。
mount 失败的原因是:以 VirtualBox 为 backend 的 Rex-Ray volume 不支持同时 attach 到多个 Host。需要注意:这实际上是 VirtualBox 的限制,而非 Rex-Ray。如果 backend 选择 Ceph RBD 就没有这个问题。[b]更新 Volume[/b]更新 volume 的内容。

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

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

[b]Failover[/b]现在模拟故障情况。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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  Docker 容器教程 Swarm
相关文章推荐