Docker Swarm(六)Label 节点标签与服务约束

前言

多节点 Swarm 集群下,可能节点的配置不同(比如 CPU、内存等),部署着不同类型的服务(比如 Web服务、Job服务等),当这些服务以 Service 或者 Stack 的形式部署到集群,默认情况下会随机分配到各个节点。

  • 场景1:不同类型的服务对服务器需求的资源是不同的,为了更合理的利用服务器资源,我们可能希望某些服务能够部署到指定的服务器上。
  • 场景2:Swarm 集群中的节点跨机房,为了内部服务间通信更快,我们可能希望关联比较密切的服务能够部署到同一机房的节点上。

以上场景要如何做到呢? 很简单,先给节点添加标签,然后服务发布时添加限制条件即可!

 
 

Node Label 管理

示例集群信息:

Docker Swarm(六)Label 节点标签与服务约束

  • 添加标签
docker node update --label-add role=masl manager-node
  • 查看标签
docker node inspect manager-node

Docker Swarm(六)Label 节点标签与服务约束

  • 删除标签
docker node update --label-rm role manager-node


服务部署条件约束

Service 方式

docker service create --name masl -e TZ="Asia/Shanghai" --network mrp_net --replicas 2 -p 8081:8080 --constraint ‘node.labels.role == masl‘ 172.16.99.2:40305/masl:dev-yc-67
  • Stack 方式
version: ‘3.6‘
services:
    masl:
         image: 172.16.99.2:40305/masl:dev-yc-67
         ports:
           - target: 8080
             published: 8081
             protocol: tcp
             mode: ingress
         deploy:
           mode: global
           placement:
              constraints:                      # 添加条件约束
                - node.labels.role==role
           restart_policy:
             condition: on-failure
             max_attempts: 3

注:constraints 为数组,填写多个约束时,它们之间的关系是 AND

 
 

条件约束补充

constraints 可以匹配 node 标签和 engine 标签,engine.labels 适用于 Docker Engine 标签,如操作系统,驱动程序等,node.labels 适用于上述人为添加到节点的。
nodeattribute matchesexample
node.idNode IDnode.id==2ivku8v2gvtg4
node.hostnameNode hostnamenode.hostname!=node-2
node.roleNode rolenode.role==manager
node.labelsuser defined node labelsnode.labels.security==high
engine.labelsDocker Engine‘s labelsengine.labels.operatingsystem==ubuntu 14.04
 
 


参考链接:https://www.jianshu.com/p/2a11a40a9573