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

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

※ 添加标签

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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值