验证 Swarm 数据持久性 - 每天5分钟玩转 Docker 容器技术(104)
上一节我们成功将 Rex-Ray Volume 挂载到了 Service。本节验证 Failover 时,数据不会丢失。
Scale Up
增加一个副本:
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 就没有这个问题。
更新 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
本文转自CloudMan6 51CTO博客,原文链接:http://blog.51cto.com/cloudman/2049248

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
replicated vs global mode - 每天5分钟玩转 Docker 容器(105)
Swarm 可以在 service 创建或运行过程中灵活地通过--replicas调整容器副本的数量,内部调度器则会根据当前集群的资源使用状况在不同 node 上启停容器,这就是 service 默认的replicatedmode。在此模式下,node 上运行的副本数有多有少,一般情况下,资源更丰富的 node 运行的副本数更多,反之亦然。 除了replicatedmode,service 还提供了一个globalmode,其作用是强制在每个 node 上都运行一个且最多一个副本。 此模式特别适合需要运行 daemon 的集群环境。比如要收集所有容器的日志,就可以globalmode 创建 service,在所有 node 上都运行gliderlabs/logspout容器,即使之后有新的 node 加入,swarm 也会自动在新 node 上启动一个gliderlabs/logspout副本。 docker service create \ --mode global \ --name logspout \ --mount type=bind,source=/va...
- 下一篇
如何滚动更新 Service?- 每天5分钟玩转 Docker 容器技术(102)
在前面的实验中,我们部署了多个副本的服务,本节将讨论如何滚动更新每一个副本。 滚动更新降低了应用更新的风险,如果某个副本更新失败,整个更新将暂停,其他副本则可以继续提供服务。同时,在更新的过程中,总是有副本在运行的,因此也保证了业务的连续性。 下面我们将部署三副本的服务,镜像使用 httpd:2.2.31,然后将其更新到 httpd:2.2.32。 创建服务: dockerservicecreate--namemy_web--replicas=3httpd:2.2.31 将 service 更新到 httpd:2.2.32: dockerserviceupdate--imagehttpd:2.2.32my_web --image指定新的镜像。 Swarm 将按照如下步骤执行滚动更新: 停止第一个副本。 调度任务,选择 worker node。 在 worker 上用新的镜像启动副本。 如果副本(容器)运行成功,继续更新下一个副本;如果失败,暂停整个更新过程。 docker service ps查看更新结果。 三个副本都已经更新到 httpd:2.2.32。 默认配置下,Swar...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- Eclipse初始化配置,告别卡顿、闪退、编译时间过长
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS7设置SWAP分区,小内存服务器的救世主
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8编译安装MySQL8.0.19
- Red5直播服务器,属于Java语言的直播服务器
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- SpringBoot2整合Redis,开启缓存,提高访问速度