如何在部署注册表时解决此问题"docker swarm中没有合适的节点(1节点上不满足调度约束)"?

Aru*_*ith 10 docker docker-registry docker-swarm docker-swarm-mode

我在一个虚拟机中有一个docker swarm,它有2个核心4GB ram Centos.

在我部署docker私有注册表(注册表2.6.4)时,它将服务状态显示为永久挂起.我用了 docker service ps <<registry_name>>

当我docker inspect <<task_id>>在消息中检查使用时,我得到了 "没有合适的节点(在1节点上不满足调度约束)".

我尝试了服务重启和重新部署.

如何解决这个问题?

Joã*_*tos 7

当组合文件中定义的节点标签与实际节点中定义的节点标签不匹配时,我经常遇到这个问题,因为我设置了错误的标签(例如拼写错误)或者根本忘记标记节点.

标记节点:

1)对于每个目标节点执行:

docker-machine ssh <manager_node_name> 'docker node update --label-add <label_name>=<label_value> <target_node_name>'

2)确保它们与compose文件中定义的匹配.

3)在管理器节点中重启docker service

例如:

撰写文件:

 dummycontainer:
    image: group/dummyimage
    deploy:
      mode: replicated
      replicas: 1
      placement:
        constraints: [node.labels.dummy_label == dummy]
      restart_policy:
        condition: on-failure
Run Code Online (Sandbox Code Playgroud)

假设我想在名为dummy_node的节点中部署此副本:

docker-machine ssh manager_node 'docker node update --label-add dummy_label=dummy dummy_node'
Run Code Online (Sandbox Code Playgroud)

并在管理器节点中重新启动docker.

最后,如果部署,您应该期望在dummy_node中运行dummycontainer,假设在两个步骤中都正确设置了标签.否则可以预见到你得到的错误.

最好的祝福


Sur*_*tel 6

我在部署服务时遇到了类似的问题,检查节点的可用性,并docker node ls检查节点是否未设置为drain并更新为active使用docker node update --availability active <node-id>

这将允许 swarm 在该服务的节点上运行容器。