为了账号安全,请及时绑定邮箱和手机立即绑定

Docker Swarm 进阶: 节点标签与服务

标签:
Docker

webp

坐我旁边的妹子

多节点 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                                  18.03.0-ce

※ 添加标签

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

※ Stack 方式

version: '3.6'services:
    mycat:
         image: nginx
         ports:
           - target: 8080
             published: 8080
             protocol: tcp
             mode: ingress
         deploy:
           mode: global
           placement:
              constraints:                      # 添加条件约束
                - node.labels.role==web
           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



作者:Anoyi
链接:https://www.jianshu.com/p/2a11a40a9573


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消