标签:-- span ons alt 示例 shu war OLE class
多节点 Swarm 集群下,可能节点的配置不同(比如 CPU、内存等),部署着不同类型的服务(比如 Web服务、Job服务等),当这些服务以 Service 或者 Stack 的形式部署到集群,默认情况下会随机分配到各个节点。
以上场景要如何做到呢? 很简单,先给节点添加标签,然后服务发布时添加限制条件即可!
示例集群信息:
docker node update --label-add role=masl manager-node
docker node inspect manager-node
docker node update --label-rm role manager-node
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
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
适用于上述人为添加到节点的。node | attribute matches | example |
---|---|---|
node.id | Node ID | node.id==2ivku8v2gvtg4 |
node.hostname | Node hostname | node.hostname!=node-2 |
node.role | Node role | node.role==manager |
node.labels | user defined node labels | node.labels.security==high |
engine.labels | Docker Engine‘s labels | engine.labels.operatingsystem==ubuntu 14.04 |
Docker Swarm(六)Label 节点标签与服务约束
标签:-- span ons alt 示例 shu war OLE class
原文地址:https://www.cnblogs.com/caoweixiong/p/12382282.html