Docker - Swarm

2017-10-04  本文已影响0人  peter_yzq

前几篇文章里的Docker 应用都是在单个机器或者vm上运行的,这篇文章会提到一个新的概念:Cluster(集群)。把应用部署到一个集群中表示它将会运行在多台机器上。Docker化的Cluster称为Swarm。
(https://docs.docker.com/get-started/part4/#understanding-swarm-clusters)

Swarm Cluster:

Swarm manager 运行容器的策略:

下面开始搭建一个swarm。为了方便,swarm里面的机器都使用虚拟机。

1:swarm 初始化:
docker swarm init

2:新建立一个虚拟机做为worker node。使用默认的vm做为manage node:

docker-machine create --driver virtual box worker

查看当前的虚拟机:

#docker-machine ls
NAME      ACTIVE   DRIVER       STATE     URL                         SWARM   DOCKER        ERRORS
default   *        virtualbox   Running   tcp://192.168.99.100:2376           v17.09.0-ce   
worker    -        virtualbox   Running   tcp://192.168.99.103:2376           v17.09.0-ce 

3:worker vm 加入集群做为worker node。

docker-machine ssh worker "docker swarm join --token SWMTKN-1-40e8mrtt3z7yu6c2zuwazlrjay9xuqij9mlgmm239rdeotrwp6-3qyh85qm4n8yyuq04opu5ieju 192.168.99.100:2377"
This node joined a swarm as a worker.

把应用部署到集群中:

(这里和官网的文档有些不一样,我是把default的vm做为swarm manager,所以并不需要通过 docker-machine ssh default 的方式去执行命令)

docker stack deploy -c docker-compose.yml getstartedlab

通过
docker stack ps getstartedlab
命令可以查看到 getstartedlab 被分布运行在default vm 和 worker vm上。

移除应用:

docker stack rm getstartedlab

离开swarm 集群:

docker swarm leave --force

其它:
删除一个vm的命令:
docker-machine rm myvm1
启动一个vm的命令:
docker-machine start myvm1
停止一个vm的命令:
docker-machine stop myvm1

上一篇 下一篇

猜你喜欢

热点阅读