前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker Swarm 进阶: 节点标签与服务

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

作者头像
轻量级云原生架构实验室
发布2018-08-16 17:47:17
1.4K0
发布2018-08-16 17:47:17
举报
文章被收录于专栏:轻量级微服务
多节点 Swarm 集群下,可能节点的配置不同(比如 CPU、内存等),部署着不同类型的服务(比如 Web服务、Job服务等),当这些服务以 Service 或者 Stack 的形式部署到集群,默认情况下会随机分配到各个节点。不同类型的服务对服务器需求的资源是不同的,为了更合理的利用服务器资源,我们可能希望某些服务能够部署到指定的服务器上。另外一种场景,Swarm 集群中的节点跨机房,为了内部服务间通信更快,我们可能希望关联比较密切的服务能够部署到同一机房的节点上。那么,如何做到呢?

很简单,先给节点添加标签,然后服务发布时添加限制条件即可!

Node Label 管理

示例集群信息:

代码语言:javascript
复制
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

※ 添加标签

代码语言:javascript
复制
docker node update --label-add role=web node1

※ 查看标签

代码语言:javascript
复制
docker node inspect node1
代码语言:javascript
复制
[
    {
        "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"
        }
       # 省略
    }
]

※ 删除标签

代码语言:javascript
复制
docker node update --label-rm role node1

服务部署条件约束

※ Service 方式

代码语言:javascript
复制
docker service create \
  --name nginx_2 \
  --constraint 'node.labels.role == web' \
  nginx

※ Stack 方式

代码语言:javascript
复制
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 适用于上述人为添加到节点的。

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018.08.07 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Node Label 管理
  • 服务部署条件约束
  • 条件约束补充
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档