我认为这个问题是由 kuberadm 首先 init coredns 而不是 init flannel 引起的,所以它抛出“网络插件未准备好:cni config uninitialized”。
解决方法:
1.通过安装flannel kubectl -n kube-system apply -f https://raw.githubusercontent.com/coreos/flannel/bc79dd1505b0c8681ece4de4c0d86c5cd2643275/Documentation/kube-flannel.yml
2.reset coredns pod
kubectl delete coredns-xx-xx
3.然后运行kubectl get pods
看看是否有效。
如果您看到此错误“cni0”已经具有不同于 10.244.1.1/24 的 IP 地址。请按照以下步骤操作:
ifconfig cni0 down
brctl delbr cni0
ip link delete flannel.1
如果您看到此错误“Back-off restarting failed container”,您可以通过以下方式获取日志
root@master:/home/moonx/yaml# kubectl logs coredns-86c58d9df4-x6m9w -n=kube-system
.:53
2019-01-22T08:19:38.255Z [INFO] CoreDNS-1.2.6
2019-01-22T08:19:38.255Z [INFO] linux/amd64, go1.11.2, 756749c
CoreDNS-1.2.6
linux/amd64, go1.11.2, 756749c
[INFO] plugin/reload: Running configuration MD5 = f65c4821c8a9b7b5eb30fa4fbc167769
[FATAL] plugin/loop: Forwarding loop detected in "." zone. Exiting. See https://coredns.io/plugins/loop#troubleshooting. Probe query: "HINFO 1599094102175870692.6819166615156126341.".
然后你可以在失败的节点上看到文件“/etc/resolv.conf”,如果nameserver是localhost会有一个loopback。改成:
#nameserver 127.0.1.1
nameserver 8.8.8.8