Node Label节点标签与服务约束

271 阅读1分钟

在多节点的Swarm集群下,存在某些节点的配置不同,部署不同类型的服务部署在不同配置或者环境的节点上。当这些服务以Serice或者Stack的形式部署到集群,默认情况下会随机分配到各个节点。不同类型的服务对服务器需求的资源是不同的,为了更合理的利用服务器资源,我们可能希望某些服务能够部署到指定的服务器上。

实现的方式,很简单,是通过给节点添加标签,在发布服务的时添加限制条件。

Node Label

查看集群信息

docker node list

添加标签

docker node update --label-add role=base kvm-10-115-80-116

查看标签

 docker node inspect kvm-10-115-80-116

删除标签

docker node update --label-rm role kvm-10-115-80-116

服务部署配置

Service创建命令

docker service create \
  --name nginx_2 \
  --constraint 'node.labels.role == base' \
  nginx

Portainer创建服务

条件约束补充

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