k8s部署kubeadm init初始化不成功,coredns处于pending,master和nodes处于notready状态

声明:本文仅为个人学习笔记使用,解决方法参考原文:

https://blog.csdn.net/Harry_mumu/article/details/132099876

在部署完k8s集群后,节点一直处于notready状态(master和nodes)

  • 查看kubectl get pods -n kube-system,发现coredns一直在pending

  • 查看有问题的pod
kubectl describe po coredns-58cc8c89f4-wvm2z -n kube-system|less 

报错显示:2个节点都有污点,因此无法调度

  • 对k8s-node1进行排查
kubectl describe nodes k8s-node1|less

 

报错:failed to find plugin "flannel" in path /opt/cni/bin

解决方法:手动下载插件

https://github.com/containernetworking/plugins/releases/download/v0.8.6/cni-plugins-linux-amd64-v0.8.6.tgz

  • 解压,复制到相应目录:
tar -zxvf cni-plugins-linux-amd64-v0.8.6.tgz -C /opt/cni-plugins/

cp flannel /opt/cni/bin/
  • 在master执行完上述操作后master变为ready

  • 再在node1节点上执行相同的操作就可以了

后来我尝试如下方式部署集群的时候:

 https://www.cnblogs.com/xuweiweiwoaini/p/13884112.html

也会出现notready的现象,当时的报错不仅cordns一直处于pending的状态,还会有一些镜像无法安装

基本的解决思路是:

  • 手动安装无法pull的镜像
  • 删除某个文件的某一部分内容,具体是啥忘记了,大概也是和系统的配置相关,原文章找不到了 (vim打开是全红色的,只有一行)

完成上述操作之后我的master就变成ready了,但是node还是notready,接下来的操作就是在master上手动安装上述的插件(不需要在node上操作),然后此时查看node的日志还是会报错failed to find plugin "flannel" in path /opt/cni/bin,在master上把flannel拷贝到node的/opt/cni/bin目录就好了。(如果基于第一种方法安装的话会提示目录找不到)

集群部署参考:

http://t.csdnimg.cn/CGltq

重新初始化可能会用到的一些命令及方法:

https://blog.csdn.net/weixin_58746210/article/details/139882088

  • 24
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值