假设我们以群体模式工作,我们有三个节点:
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/
|