声明:本文仅为个人学习笔记使用,解决方法参考原文:
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