请选择 进入手机版 | 继续访问电脑版
  • 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

Docker群仅在worker中运行任务

[复制链接]
菜鸟教程小白 发表于 2022-8-3 10:13:57 | 显示全部楼层 |阅读模式 打印 上一主题 下一主题

假设我们以群体模式工作,我们有三个节点:

  • manager1
  • worker1
  • worker2

  • 是否可以创建服务并指定任务仅在 worker (worker1和worker2)中运行,而不必在管理者(manager1)中运行

    我正在运行以下命令来创建服务:
    docker-machine ssh manager1 "docker service create --network dognet --name dog-db redis"
    

    当我ps服务时:
    docker-machine ssh manager1 "docker service ps dog-db"
    

    我得到:
    ID                         NAME      IMAGE  NODE      DESIRED STATE  CURRENT STATE            ERROR
    3kvfpbhl6fj0qwtglc5k7sbkw  dog-db.1  redis  manager1  Running        Preparing 4 seconds ago  
    



    Best Answer-推荐答案


    尽管您可以使用约束(带有--constraint node.role=worker)根据其角色(管理者或工作人员)消除节点的子集,但我会尽其所能地通过禁止管理器像以下工作人员一样工作::

    # Disables the Manager as a Worker node
    
    docker node update --availability drain manager1
    

    这个想法是要确保Manager不受资源过载(CPU,RAM,fds)的影响,如果部署的服务使用的资源高于Manager上可用的资源,则可能发生这种情况。它可能会触发故障级联方案,并且群集可能变得高度不稳定(或不再响应任何其他请求)。

    Manager的核心维护着关键组件(例如证书颁发和轮换,分布式数据存储,网络连接),这会导致整个群集不稳定,这是很糟糕的,因为Manager的资源不足。

    相关问题:
  • How to kill your Managers
  • Orchestrator does not handle dynamic updates in tasks scaling

  • 资料来源:我是Docker Swarm的维护者,并为Swarm模式编写了Administration Guide

    关于Docker群仅在worker中运行任务,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40796494/

    回复

    使用道具 举报

    懒得打字嘛,点击右侧快捷回复 【右侧内容,后台自定义】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    关注0

    粉丝0

    帖子520893

    发布主题
    阅读排行 更多
    广告位

    扫描微信二维码

    查看手机版网站

    随时了解更新最新资讯

    139-2527-9053

    在线客服(服务时间 9:00~18:00)

    在线QQ客服
    地址:深圳市南山区西丽大学城创智工业园
    电邮:jeky_zhao#qq.com
    移动电话:139-2527-9053

    Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap