上一节我们成功将 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

最新文章

  1. PHP好用但又容易忽略的小知识
  2. makefile--subst
  3. C++ 知道虚函数表的存在
  4. Page Scroll Effects - 简单的页面滚动效果
  5. Chronos
  6. codeforces A. The Wall 解题报告
  7. markdown 语法学习
  8. DatagramChannel
  9. iBeacon开发
  10. POJ1185 炮兵阵地 状态压缩
  11. VS2010 MSDN的介绍
  12. javaSE_06Java中的数组(array)
  13. Java ASM介绍
  14. 胖虎都看得懂的CSS入门
  15. Android自动化框架介绍
  16. linux学习:网络(防火墙)及系统安全相关命令学习
  17. exchange 2010 数据库管理
  18. collections集合模块 [namedtuple,deque,*]
  19. 微软BI 之SSIS 系列 - 理解Data Flow Task 中的同步与异步, 阻塞,半阻塞和全阻塞以及Buffer 缓存概念
  20. postman 带变量参数使用方法

热门文章

  1. Nodejs.安装.非源码方式安装Node.js (Centos)
  2. LeetCode 562. Longest Line of Consecutive One in Matrix(在矩阵中最长的连续1)$
  3. LeetCode 283. Move Zeroes (移动零)
  4. LeetCode 226. Invert Binary Tree (反转二叉树)
  5. Django+Nginx+uWSGI部署
  6. Machine-learning of Andrew Ng(Stanford University)
  7. angualr高级篇之elem.scope()、elem.isolateScope和$compile(elem)(scope)中scope的区别
  8. Leetcode题解(一)
  9. React + Node 单页应用「一」前端搭建
  10. RPA(Robotic Process Automation)的概要介绍