Docker swarm只在worker中运行任务

dfuffjeb  于 2023-03-29  发布在  Docker
关注(0)|答案(3)|浏览(154)

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

  • 经理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
jk9hmnmh

jk9hmnmh1#

虽然您可以使用constraints(与--constraint node.role=worker一起使用)来根据节点的角色(manager或worker)消除节点的子集,但我会使用以下命令禁用Manager(s),使其无法像Worker(s)一样工作

# Disables the Manager as a Worker node

docker node update --availability drain manager1

这个想法是,管理器应该保持安全,防止资源过载(CPU,RAM,fds),如果部署的服务使用的资源高于管理器上可用的资源,可能会发生这种情况。它可以触发 * 故障级联场景 *,集群可能变得非常不稳定(或不响应任何更多的请求)。
管理器的核心是维护关键组件(如证书颁发和轮换、分布式数据存储、网络),由于管理器资源不足而使整个群集不稳定是不好的。
相关问题:

t8e9dugd

t8e9dugd2#

可以,您可以基于节点角色约束服务。请将命令更改为:
docker service create --network dognet --constraint node.role==worker --name dog-db redis

qzwqbdag

qzwqbdag3#

通过docker-composite.yaml或stack-deploy.yaml文件进行堆栈部署的way to do this包含deploy.placement.constraints密钥:

#stack-deploy.yaml
services:
    your_service:
        deploy:
            placement:
                constraints:
                    -"node.role==worker"

此约束将由stack deploy命令拾取:

$ docker stack deploy -c stack-deploy.yaml your_app

https://docs.docker.com/engine/reference/commandline/service_create/#constraint

相关问题