K8S子节点加入主节点访问MaterAPI报错:Unauthorized 401

问题场景:

本地测试由于之前安装过K8S今天重启无法使用了,于是重新安装了一下,子节点加入主节点报错:

复制代码
I0808 23:13:04.299356   19180 round_trippers.go:466] curl -v -XGET  -H "Accept: application/json, */*" -H "User-Agent: kubeadm/v1.24.9 (linux/amd64) kubernetes/9710807" 'https://192.168.1.100:6443/api/v1/nodes/node1?timeout=10s'
I0808 23:13:04.300840   19180 round_trippers.go:553] GET https://192.168.1.100:6443/api/v1/nodes/node1?timeout=10s 401 Unauthorized in 1 milliseconds
I0808 23:13:04.300854   19180 round_trippers.go:570] HTTP Statistics: GetConnection 0 ms ServerProcessing 1 ms Duration 1 ms
I0808 23:13:04.300860   19180 round_trippers.go:577] Response Headers:
I0808 23:13:04.300866   19180 round_trippers.go:580]     Audit-Id: 1c5934bb-82ed-4955-9499-84ec4397a8f0
I0808 23:13:04.300871   19180 round_trippers.go:580]     Cache-Control: no-cache, private
I0808 23:13:04.300876   19180 round_trippers.go:580]     Content-Type: application/json
I0808 23:13:04.300881   19180 round_trippers.go:580]     Content-Length: 129
I0808 23:13:04.300886   19180 round_trippers.go:580]     Date: Thu, 08 Aug 2024 15:13:04 GMT
I0808 23:13:04.300902   19180 request.go:1154] Response Body: {"kind":"Status","apiVersion":"v1","metadata":{},"status":"Failure","message":"Unauthorized","reason":"Unauthorized","code":401}

问题解决办法:

先说一下原因:是之前加入过,有一些残留文件但是删除了还是没有删除干净。那就需要reset一下,执行命令即可:

复制代码
[root@node1 ~]# kubeadm reset -f

此时再次join没有问题成功。

补充:

1、调试技巧还是在join下增加一个输出细节级别 --v 方便调试:

复制代码
[root@node1 ~]# kubeadm join 192.168.1.100:6443 --token mk6uf1.eef01he2iqok22tm         --discovery-token-ca-cert-hash sha256:e0ad6e494a6c6b192b88f136a96c421e28d63b235b54091bf04faa5db36aa609 --v=10

2、一键清理并reset,之心过后直接可以运行join:

复制代码
[root@node1 ~]# rm -rf /root/.kube && rm -rf /etc/cni/net.d && rm -rf /etc/kubernetes/* && kill -9 $(lsof -i:10250 |awk 'NR>1 {print $2}') && kubeadm reset -f
相关推荐
吃饱了得干活15 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx5728017 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
Flynt18 小时前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
plainGeekDev19 小时前
Activity 间传值 → Navigation 参数
android·java·kotlin
plainGeekDev19 小时前
onActivityResult → ActivityResult API
android·java·kotlin
Sunia19 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构
ZhengEnCi20 小时前
J7A-高级Java工程师面试三道灵魂拷问-深度广度与工程素养的终极检验
java·后端
狼爷2 天前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
祎雪双十Gy2 天前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
运维开发故事2 天前
基于 Arthas 的多集群在线诊断系统设计与实现
kubernetes