Назад | Перейти на главную страницу

Состояние: ответ об ошибке от демона: узел elk12 неоднозначен (найдено 2 совпадения), код: 1

Я использую следующую среду: Debian 9 с Docker CE:

# cat /etc/os-release 
PRETTY_NAME="Debian GNU/Linux 9 (stretch)"
NAME="Debian GNU/Linux"
VERSION_ID="9"
VERSION="9 (stretch)"
ID=debian
HOME_URL="https://www.debian.org/"
SUPPORT_URL="https://www.debian.org/support"
BUG_REPORT_URL="https://bugs.debian.org/"
# docker --version
Docker version 17.09.0-ce, build afdb6d4
# 

docker node ls:

# docker node ls | grep elk12
2keku0oj8zhsy6uyvyl4gd4d7     elk12               Down                Active              Reachable
tbwbpkl5qys4wwxbisga3y2oe *   elk12               Ready               Active              Reachable
# docker node inspect elk12
[]
Status: Error response from daemon: node elk12 is ambiguous (2 matches found), Code: 1
#

Я не могу использовать docker node rm elk12, поскольку я, согласно приведенному выше выводу, у меня 2.

Как продолжить удаление "неработающего" узла из списка, желательно не затрагивая рабочий кластер). Я даже не верю, что у меня вообще есть этот узел (возможно, некоторые остатки от давних времен) ...

Пожалуйста, порекомендуйте.


ОБНОВИТЬ:

# docker node rm 2keku0oj8zhsy6uyvyl4gd4d7
Error response from daemon: rpc error: code = FailedPrecondition desc = node 2keku0oj8zhsy6uyvyl4gd4d7 is a cluster manager and is a member of the raft cluster. It must be demoted to worker before removal
# docker node demote 2keku0oj8zhsy6uyvyl4gd4d7
Manager 2keku0oj8zhsy6uyvyl4gd4d7 demoted in the swarm.
# docker node rm 2keku0oj8zhsy6uyvyl4gd4d7
2keku0oj8zhsy6uyvyl4gd4d7
# docker node ls | grep elk12
tbwbpkl5qys4wwxbisga3y2oe     elk12               Ready               Active              Reachable
# 

Объясняется проблема с дублированным узлом с тем же именем, но с другим идентификатором. Вот, возможно, узел, который покинул рой и присоединился к нему, перезапуск менеджера ...

Если вы хотите удалить дублированный узел и избавиться от этого неоднозначного предупреждения, вы можете использовать хэш-идентификатор, а не имя:

docker node rm 2keku0oj8zhsy6uyvyl4gd4d7

Если вы хотите удалить другой узел с именем elk12, кажется, что этот узел является менеджером, поэтому вам следует действовать с осторожностью, так как вы можете столкнуться с проблемами, если не будет достаточно менеджеров. достичь консенсуса. Если вы считаете, что удалить этот управляющий узел безопасно, потому что у вас достаточно узлов, работающих в качестве менеджеров в вашем рое, вы должны выполнить следующее:

  1. Понизьте уровень управляющего узла (понизьте уровень узла докера). Таким образом, этот узел больше не является узлом-менеджером и работает как рабочий узел.
  2. Осушите рабочий узел (слив докер-узла). Контейнеры, работающие в elk2, будут перемещены на другие рабочие узлы в кластере.
  3. Сделайте так, чтобы рабочий узел покинул Swarm (docker swarm покинул узел elk2)
  4. Удалите узел (docker node rm ...)