K8S中master节点部署Pod处于Pending状态

查询一下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

在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当一个Pod处于Pending状态时,这意味着它还没有被调度到一个节点上运行。要检查并定位导致Pod处于Pending状态的原因,可以执行以下步骤: 1. 使用`kubectl get pods`命令检查Pod状态和事件: ``` kubectl get pods ``` 这将列出集群所有Pod状态。查找处于Pending状态Pod,并查看它的事件列,可以得到一些关于为什么Pod无法调度的信息。 2. 检查Pod的调度限制和资源需求: 使用`kubectl describe pod <pod-name>`命令来获取有关Pod的详细信息,包括调度限制和资源需求。查看`Conditions`部分的信息,特别是`PodScheduled`条件,看看是否有任何错误或警告。 ``` kubectl describe pod <pod-name> ``` 在描述,注意查看`Events`部分,它可以提供关于为什么Pod无法调度的有用信息。 3. 检查节点资源: 检查集群节点资源情况,确保有足够的可用资源(如CPU、内存)来调度Pod。可以使用以下命令来获取节点的资源使用情况: ``` kubectl describe node <node-name> ``` 在描述,查看`Allocated resources`部分以了解已经在节点上分配了多少资源。 4. 检查调度策略和节点选择器: 检查Pod的调度策略和节点选择器,确保它们与可用的节点匹配。如果Pod指定了节点选择器,并且没有满足该选择器的节点可用,那么Pod将一直处于Pending状态。确保节点选择器与节点的标签匹配。 ``` kubectl describe pod <pod-name> ``` 在描述,查找`Node Selector`部分以查看Pod节点选择器。 通过这些步骤,你应该能够检查并定位导致Pod处于Pending状态的原因。根据具体情况,你可能需要调整调度限制、资源需求、节点资源或节点选择器来解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值