小编典典

Docker群仅在工作线程中运行任务

docker

假设我们正在集群模式下工作,我们有三个节点:

  • 经理1
  • 工人1
  • 工人2

是否可以创建服务并指定任务仅在工作者(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

阅读 242

收藏
2020-06-17

共1个答案

小编典典

虽然您可以使用 约束 (带有--constraint node.role=worker)根据节点的角色(管理者或工作人员)消除节点的子集,但我将通过以下方式 使Manager不再像Worker那样工作

# Disables the Manager as a Worker node

docker node update --availability drain manager1

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

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

相关问题:

资料来源 :我是Docker
Swarm的维护者,并撰写了Swarm模式管理指南

2020-06-17