Docker - Swarm

前几篇文章里的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

你可能感兴趣的:(Docker - Swarm)