查询一下pod信息:
kubectl get pods -n kubernetes-dashboard
根据name查看详细信息:
kubectl describe pod dashboard-metrics-scraper-5b59d4bc6b-rxgqb -n kubernetes-dashboard
这一句提示:
Warning FailedScheduling 7s (x21464 over 17h) default-scheduler 0/1 nodes are available: 1 node(s) had taints that the pod didn't tolerate.
警告失败调度7s(x21464超过17h)默认调度程序0/1个节点可用:1个节点有pod无法容忍的污点。
是因为默认kubernetes默认不让pod部署到master节点,而我们部署的测试环境只有一个节点也是master节点,需要允许master节点部署pod:
首先要找到污点信息:
kubectl get no -o yaml | grep taint -A 5
注意下方返回的这个key值,清除污点的时候需要用到。
taints:
- effect: NoSchedule
key: node.kubernetes.io/not-ready
- effect: NoExecute
key: node.kubernetes.io/not-ready
timeAdded: "2023-05-16T08:06:27Z"
解决方案:手动删除master的污点;
先看一下taint命令的语法格式:
kubectl taint nodes --all 【key】-
这个key就是上面查询信息拿到的那个key。
kubectl taint nodes --all node.kubernetes.io/not-ready-
再次检查是否还有污点:
kubectl get no -o yaml | grep taint -A 5
这样治标不治本,问题的根源在于 处在not-ready状态,继续排查
kubectl get pod -n kube-system
#查看Pod详细情况
kubectl describe pod coredns-54ff9cd656-9d775 -n kube-system
发现报了这个错误:
failed to find plugin “flannel” in path [/opt/cni/bin],k8sNotReady解决方案
需要下载CNI插件:CNI plugins v0.8.6:
wget https://github.com/containernetworking/plugins/releases/download/v0.8.7/cni-plugins-linux-amd64-v0.8.7.tgz
解压:
tar zxvf cni-plugins-linux-amd64-v0.8.7.tgz
拷贝到环境目录下:
cp flannel /opt/cni/bin/
再次查看,所有pod都已经运行中了:
kubectl get pods --all-namespaces -o wide