niq*_*qui 7 service docker docker-swarm
假设我们正在以群集模式工作,并且我们有三个节点:
是否可以创建服务并指定任务只需在worker(worker1和worker2)中运行,而不是在manager(manager1)中运行
我正在运行以下命令来创建服务:
docker-machine ssh manager1 "docker service create --network dognet --name dog-db redis"
Run Code Online (Sandbox Code Playgroud)
当我提供服务时:
docker-machine ssh manager1 "docker service ps dog-db"
Run Code Online (Sandbox Code Playgroud)
我明白了:
ID NAME IMAGE NODE DESIRED STATE CURRENT STATE ERROR
3kvfpbhl6fj0qwtglc5k7sbkw dog-db.1 redis manager1 Running Preparing 4 seconds ago
Run Code Online (Sandbox Code Playgroud)
abr*_*nan 12
虽然您可以使用约束(with --constraint node.role=worker
)根据其角色(经理或工作人员)消除节点的子集,但我会尽可能地禁止管理器像工作人员一样:
# Disables the Manager as a Worker node
docker node update --availability drain manager1
Run Code Online (Sandbox Code Playgroud)
我们的想法是,应保证管理器免受资源过载(CPU,RAM,fds)的影响,如果部署的服务使用的资源高于Manager上可用的资源,则可能会发生这种情况.它可以触发故障级联场景,并且群集可能变得非常不稳定(或者不响应任何更多请求).
Manager的核心是维护关键组件(如证书颁发和轮换,分布式数据存储,网络),因为管理器资源不足,使整个集群不稳定会很糟糕.
相关问题:
来源:我是Docker Swarm的维护者,并编写了Swarm模式的管理指南.
是的,您可以基于节点角色约束服务.将您的命令更改为:
docker service create --network dognet --constraint node.role==worker --name dog-db redis
归档时间: |
|
查看次数: |
4869 次 |
最近记录: |