博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
验证 Swarm 数据持久性 - 每天5分钟玩转 Docker 容器技术(104)
阅读量:5125 次
发布时间:2019-06-13

本文共 876 字,大约阅读时间需要 2 分钟。

上一节我们成功将 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容器技术》


2.《每天5分钟玩转OpenStack》

转载于:https://www.cnblogs.com/CloudMan6/p/8016994.html

你可能感兴趣的文章
WEB_头等舱
查看>>
第九周 10.25-10.31
查看>>
Activity的四种加载模式(转载)
查看>>
【转载】MongoDB 1000W级数据 Insert和Query和Delete性能测试
查看>>
SSM项目中整合WebService
查看>>
SQL批量提交修改业务
查看>>
谈谈我对Javascript中This对象的理解
查看>>
(专题二)01 矩阵的处理-特殊矩阵
查看>>
Tomcat项目部署过程中的问题
查看>>
Unreal4(虚幻4抽茧剥丝)——02章格式化C++和蓝图
查看>>
移动端弹出层加遮罩后禁止滑动
查看>>
C# VS2017 winForm 使tableLayoutPanel 不闪烁
查看>>
执行异常ORA-00918: column ambiguously defined
查看>>
lua cURL使用笔记
查看>>
jQuery之ajax的跨域获取数据
查看>>
用键盘实现上下选择
查看>>
包含对流环热,热流边界,等温边界的稳态热传导方程的FEM求解。
查看>>
然爸读书笔记(2014-5)----团队正能量
查看>>
【翻译】使用Ext JS设计响应式应用程序
查看>>
安卓学习笔记--获取网络连接状态
查看>>