前几篇文章里的Docker 应用都是在单个机器或者vm上运行的,这篇文章会提到一个新的概念:Cluster(集群)。把应用部署到一个集群中表示它将会运行在多台机器上。Docker化的Cluster称为Swarm。
(https://docs.docker.com/get-started/part4/#understanding-swarm-clusters
)
Swarm Cluster:
- 每一个在Swarm Cluster 里面的机器称为nodes。
- Docker 命令只能Swarm manager 中运行。workers
node 只是提供资源给manager 调度,不能给其他的worker node 下发命令。
Swarm manager 运行容器的策略:
- "emptiest node": 在最空闲的机器上运行container。
- "global": 指定每一个机器上只运行特定的容器实例。
这些策略可以在docker-compose.yml 文件中指定。
下面开始搭建一个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