多节点 Swarm 集群下,可能节点的配置不同(比如 CPU、内存等),部署着不同类型的服务(比如 Web服务、Job服务等),当这些服务以 Service 或者 Stack 的形式部署到集群,默认情况下会随机分配到各个节点。不同类型的服务对服务器需求的资源是不同的,为了更合理的利用服务器资源,我们可能希望某些服务能够部署到指定的服务器上。另外一种场景,Swarm 集群中的节点跨机房,为了内部服务间通信更快,我们可能希望关联比较密切的服务能够部署到同一机房的节点上。那么,如何做到呢?
很简单,先给节点添加标签,然后服务发布时添加限制条件即可!
Node Label 管理
示例集群信息:
docker@node1:~$ docker node ls
ID HOSTNAME STATUS AVAILABILITY MANAGER STATUS ENGINE VERSION
axr4zun8u1es8ytizjpt3zlnw * node1 Ready Active Leader 18.03.0-ce
vdip2js7tfflxv0smj6wdw0bv node2 Ready Active 18.03.0-ce
vi17ametnwd58297z6nlcl2o0 node3 Ready Active
※ 添加标签
docker node update --label-add role=web node1
※ 查看标签
docker node inspect node1
[
{
"ID": "axr4zun8u1es8ytizjpt3zlnw",
"Version": {
"Index": 476
},
"CreatedAt": "2018-07-19T03:50:02.734603631Z",
"UpdatedAt": "2018-07-30T06:37:04.465194614Z",
"Spec": {
"Labels": {
"role": "web" # 人工添加的标签
},
"Role": "manager",
"Availability": "active"
}
# 省略
}
]
※ 删除标签
docker node update --label-rm role node1
服务部署条件约束
※ Service 方式
docker service create \
--name nginx_2 \
--constraint 'node.labels.role == web' \
nginx