如何实现 Service 伸缩?- 每天5分钟玩转 Docker 容器技术(97)
2017-11-24 08:32
901 查看
上一节部署了只有一个副本的 Service,不过对于 web 服务,我们通常会运行多个实例。这样可以负载均衡,同时也能提供高可用。
swarm 要实现这个目标非常简单,增加 service 的副本数就可以了。在 swarm-manager 上执行如下命令:
副本数增加到 5,通过
5 个副本已经分布在 swarm 的所有三个节点上。
默认配置下 manager node 也是 worker node,所以 swarm-manager 上也运行了副本。如果不希望在 manager 上运行 service,可以执行如下命令:
通过
swarm-manager 上的副本
前面我们的场景是 scale up,我们还可以 scale down,减少副本数,运行下面的命令:
可以看到,
Service 的伸缩就讨论到这里,下一节我们学习故障切换 Failover。
书籍:
1.《每天5分钟玩转Docker容器技术》
https://item.jd.com/16936307278.html
2.《每天5分钟玩转OpenStack》
https://item.jd.com/12086376.html
swarm 要实现这个目标非常简单,增加 service 的副本数就可以了。在 swarm-manager 上执行如下命令:
docker service scale web_server=5
副本数增加到 5,通过
docker service ls和
docker service ps查看副本的详细信息。
5 个副本已经分布在 swarm 的所有三个节点上。
默认配置下 manager node 也是 worker node,所以 swarm-manager 上也运行了副本。如果不希望在 manager 上运行 service,可以执行如下命令:
docker node update --availability drain swarm-manager
通过
docker node ls查看各节点现在的状态:
Drain表示 swarm-manager 已经不负责运行 service,之前 swarm-manager 运行的那个副本会如何处理呢?用
docker service ps查看一下:
swarm-manager 上的副本
web_server.2已经被
Shutdown了,为了达到 5 个副本数的目标,在 swarm-worker1 上添加了副本
web_server.2。
前面我们的场景是 scale up,我们还可以 scale down,减少副本数,运行下面的命令:
docker service scale web_server=3
可以看到,
web_server.4和
web_server.5这两个副本已经被删除了。
Service 的伸缩就讨论到这里,下一节我们学习故障切换 Failover。
书籍:
1.《每天5分钟玩转Docker容器技术》
https://item.jd.com/16936307278.html
2.《每天5分钟玩转OpenStack》
https://item.jd.com/12086376.html
相关文章推荐
- 如何实现 Service 伸缩?- 每天5分钟玩转 Docker 容器技术(97)
- 如何实现 Service 伸缩?- 每天5分钟玩转 Docker 容器技术(97)
- 如何实现 Service 伸缩?- 每天5分钟玩转 Docker 容器技术(97)
- overlay 如何实现跨主机通信?- 每天5分钟玩转 Docker 容器技术(52)
- overlay 如何实现跨主机通信?- 每天5分钟玩转 Docker 容器技术(52)
- 如何滚动更新 Service?- 每天5分钟玩转 Docker 容器技术(102)
- Swarm 如何实现 Failover?- 每天5分钟玩转 Docker 容器技术(98)
- Swarm 如何实现 Failover?- 每天5分钟玩转 Docker 容器技术(98)
- 如何访问 Service?- 每天5分钟玩转 Docker 容器技术(99)
- 外网如何访问 Service?- 每天5分钟玩转 Docker 容器技术(139)
- overlay 如何实现跨主机通信?- 每天5分钟玩转 Docker 容器技术(52)
- Service 之间如何通信?- 每天5分钟玩转 Docker 容器技术(101)
- 如何实现跨 Docker 主机存储?- 每天5分钟玩转 Docker 容器技术(73)
- 如何实现跨 Docker 主机存储?- 每天5分钟玩转 Docker 容器技术(73)
- Service 之间如何通信?- 每天5分钟玩转 Docker 容器技术(101)
- 如何实现跨 Docker 主机存储?- 每天5分钟玩转 Docker 容器技术(73)
- Swarm 如何实现 Failover?- 每天5分钟玩转 Docker 容器技术(98)
- 如何滚动更新 Service?- 每天5分钟玩转 Docker 容器技术(102)
- 如何滚动更新 Service?- 每天5分钟玩转 Docker 容器技术(102)
- 如何访问 Service?- 每天5分钟玩转 Docker 容器技术(99)