美文网首页Docker SwarmDocker容器技术
Docker Swarm 进阶: 节点标签与服务

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

作者: Anoyi | 来源:发表于2018-08-07 19:02 被阅读290次
    坐我旁边的妹子

    多节点 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 适用于上述人为添加到节点的。

    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

    相关文章

      网友评论

      • 科学Jia:漂亮呢:heart_eyes:
        Anoyi:@科学Jia 你这么漂亮,当程序员鼓励师是抬爱他们:smile_cat:
        科学Jia:@Anoyi 他们也说我兼职了鼓励师身份,但跟这妹子比差距有点大,以后努努力:relaxed:
        Anoyi:@科学Jia 首席程序员鼓励师,了解下:stuck_out_tongue_winking_eye:

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

      本文链接:https://www.haomeiwen.com/subject/lkwavftx.html