运行service
执行以下命令:
docker service create --name web-server httpd
通过docker service ls查看swarm中的service
REPLICAS显示当前副本信息,1/1的意思是web-server这个service期望的容器的副本量是1,目前启动的副本量是1,也就是说web-server这个service已经部署完成了
通过docker service ps 可以查看每个service的副本的状态
可以看到web-service唯一的副本被分到docker1上,当前的状态是running,
如果不放心,可以到docker1上去确认httpd容器已经运行
当前web-server在swarm中的分布
service伸缩
上面我们只有一个副本的service,不过对于web服务,我们通常会运行多个实例。这样可以负载均衡,同时也能提供高可用。
swarm实现这个目标非常简单,增加service的副本就可以了,在swarm-manager上执行如下命令:
docker service scale web-server=5
副本数增加到5,通过docker service ls和docker service ps创建、查看副本的详细信息
可以看到一共有5个副本,2个处于运行状态,3个处于prepareing状态,由于httpd的镜像没有下载完,所以还处于运行状态
5个副本已经分布在三个节点上
默认配置下manager node也是worker node,所以swarm-manager上也运行了副本,如果不希望再manager上运行service,可以执行如下命令:
docker node update --availability drain docker docker是swarm-manager的主机名
通过docker node ls查看各节点现在的状态:
现在swarm-manager node的状态是Drain状态,Drain表示swarm-manager已经不负责运行service,之前运行的那个service会如何处理呢?
通过docker service ps 查看一下:
swarm-manager 上的副本已经被shutdown了,为了达到5个副本数的目标,在docker1上添加了副本web-server.4
盗图
上面我们讨论的是scale up,我们还可以scale down,减少副本数,运行下面的命令:
docker service scale web-server=3
可以看到web-server.1和web-server.4这两个副本已经被删除了
Swarm Failover
故障是在所难免的,容器可能崩溃,Docker host可能宕机,不过幸运的是,swarm 已经内置了failover策略
创建service的时候,我们没有告诉swarm发生故障的时候该如何处理,只是说明了我们期望的状态(比如运行3个副本),swarm会尽最大的努力达成这个期望状态,无论发生什么状况
下面我们做swarm failover特性,关闭docker1
通过docker node ls查看swarm node 的状态
swarm会检测到docker1的故障,并标记为Down
我们通过docker service ps web-server,查看service的状态
可以看到,web-server.3已经从docker1上迁移到docker2上,之前运行在docker1上的副本已经处于shutdown的状态
如果将docker1重新启动 ,会发生什么变化呢?
首先查看一下docker1的状态
可以看到web-server.3这个副本依然在docker2上,没有迁回docker1上