По какой-то причине DNS-преобразователь модуля kube-controller-manager
на кубе rnet master был пуст:
docker exec kube-controller-manager cat /etc/resolv.conf
# Generated by dhcpcd
# /etc/resolv.conf.head can replace this line
# /etc/resolv.conf.tail can replace this line
Поскольку хост-сервер resolv.conf
был корректным, я просто перезапустил контейнер:
docker restart kube-controller-manager
(альтернативным уродливым способом было бы вручную редактировать resolv.conf, используя docker restart kube-controller-manager
, а затем запустить соответствующую echo XXX >> /etc/resolv.conf
... плохую идею)
Некоторые другие контейнеры могут иметь аналогичную проблему на этом узле. Это хакерский способ идентифицировать и перезапустить эти контейнеры:
cd cd /var/lib/docker/containers
ls -1 "$(grep nameserver -L */resolv.conf)" | sed -e 's#/.*##'
0c10e1374644cc262c8186e28787f53e02051cc75c1f943678d7aeaa00e5d450
70fd116282643406b72d9d782857bb7ec76dd85dc8a7c0a83dc7ab0e90d30966
841def818a8b4df06a0d30b0b7a66b75a3b554fb5feffe78846130cdfeb39899
ae356e26f1bf8fafe530d57d8c68a022a0ee0e13b4e177d3ad6d4e808d1b36da
d593735a2f6d96bcab3addafcfe3d44b6d839d9f3775449247bdb8801e2e1692
d9b0dfaa270d3f50169fb1aed064ca7a594583b9f71a111f653c71d704daf391
Перезапустить затронутые контейнеры:
cd /var/lib/docker/containers ; ls -1 $(grep nameserver -L */resolv.conf) | sed -e 's#/.*##' | xargs -n1 -r docker restart