Kubesphere安装过程中x509证书验证问题分析与解决
2025-05-14 07:11:29作者:董灵辛Dennis
问题概述
在使用Kubesphere 3.4.1版本在阿里云ECS上部署Kubernetes集群(v1.22.12)时,执行./kk create cluster -f config-sample.yaml命令后出现x509证书验证错误。错误信息显示Kubernetes API Server的证书仅对内部IP地址(10.233.0.1, 172.20.0.251, 127.0.0.1)有效,而无法验证公网IP地址(116.62.163.2)。
问题背景分析
在Kubernetes集群部署过程中,API Server会生成一个TLS证书用于安全通信。默认情况下,这个证书只包含集群内部使用的IP地址和域名。当尝试通过外部IP地址访问API Server时,由于证书中不包含该IP地址,就会触发x509证书验证错误。
根本原因
- 证书SAN配置不足:Kubernetes API Server的证书没有包含公网IP地址作为Subject Alternative Name (SAN)
- 网络配置问题:在阿里云环境下,通常使用SLB(负载均衡)暴露API Server服务,但证书没有包含SLB的IP地址
- Kubekey配置缺失:在创建集群时,没有正确配置控制平面的externalIPs或certSANs参数
解决方案
方法一:修改Kubekey配置文件
在config-sample.yaml中添加以下配置:
spec:
controlPlaneEndpoint:
domain: lb.kubesphere.local
address: "116.62.163.2"
port: 6443
kubernetes:
apiServer:
certSANs:
- 116.62.163.2
- 10.233.0.1
- 172.20.0.251
- 127.0.0.1
方法二:手动更新API Server证书
如果集群已经部分创建,可以手动更新证书:
-
备份现有证书:
sudo cp -r /etc/kubernetes/pki /etc/kubernetes/pki-backup -
编辑kubeadm-config ConfigMap:
kubectl -n kube-system edit cm kubeadm-config在apiServer部分添加certSANs配置
-
重新生成证书:
kubeadm init phase certs apiserver --config /etc/kubernetes/kubeadm-config.yaml -
重启API Server:
docker restart $(docker ps | grep kube-apiserver | awk '{print $1}')
最佳实践建议
- 预规划网络拓扑:在部署前明确所有需要访问API Server的IP地址和域名
- 完整证书配置:确保证书包含以下SAN:
- 所有节点IP(包括公网和内网)
- 负载均衡IP
- 可能的DNS名称
- 127.0.0.1和localhost
- 使用内部域名:建议使用内部域名而非直接IP访问API Server
- 证书自动更新:配置证书自动更新机制,避免证书过期问题
总结
在云环境部署Kubesphere时,正确处理API Server证书的SAN配置是关键。通过预先规划网络架构、正确配置Kubekey参数,可以避免此类证书验证问题,确保集群部署顺利进行。对于已经出现的问题,可以通过修改配置或手动更新证书的方式解决。
登录后查看全文
热门项目推荐
相关项目推荐
Kimi-K2.5Kimi K2.5 是一款开源的原生多模态智能体模型,它在 Kimi-K2-Base 的基础上,通过对约 15 万亿混合视觉和文本 tokens 进行持续预训练构建而成。该模型将视觉与语言理解、高级智能体能力、即时模式与思考模式,以及对话式与智能体范式无缝融合。Python00
GLM-4.7-FlashGLM-4.7-Flash 是一款 30B-A3B MoE 模型。作为 30B 级别中的佼佼者,GLM-4.7-Flash 为追求性能与效率平衡的轻量化部署提供了全新选择。Jinja00
new-apiAI模型聚合管理中转分发系统,一个应用管理您的所有AI模型,支持将多种大模型转为统一格式调用,支持OpenAI、Claude、Gemini等格式,可供个人或者企业内部管理与分发渠道使用。🍥 A Unified AI Model Management & Distribution System. Aggregate all your LLMs into one app and access them via an OpenAI-compatible API, with native support for Claude (Messages) and Gemini formats.JavaScript01
idea-claude-code-gui一个功能强大的 IntelliJ IDEA 插件,为开发者提供 Claude Code 和 OpenAI Codex 双 AI 工具的可视化操作界面,让 AI 辅助编程变得更加高效和直观。Java00
KuiklyUI基于KMP技术的高性能、全平台开发框架,具备统一代码库、极致易用性和动态灵活性。 Provide a high-performance, full-platform development framework with unified codebase, ultimate ease of use, and dynamic flexibility.Kotlin06
ebook-to-mindmapepub、pdf 拆书 AI 总结TSX00
最新内容推荐
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
515
3.7 K
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
874
546
Ascend Extension for PyTorch
Python
317
362
暂无简介
Dart
759
182
React Native鸿蒙化仓库
JavaScript
299
347
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
334
156
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
1.31 K
734
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
12
1
华为昇腾面向大规模分布式训练的多模态大模型套件,支撑多模态生成、多模态理解。
Python
110
128