k8s证书过期带来的问题解决

本文涉及的产品
应用实时监控服务-可观测链路OpenTelemetry版,每月50GB免费额度
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
可观测监控 Prometheus 版,每月50GB免费额度
简介: 解决k8s自带签名证书过期后,节点状态为NotReady的恢复。

现象:

首先是master节点,执行kubectl get nodes 报错,在对master节点恢复后,恢复方法如下:

sudo kubeadm certs renew all --config=./kubeadm-init-config.yaml

后,发现worker节点依然是not ready状态:

kiosk@k8s-master:~$ k get nodes
NAME          STATUS     ROLES           AGE    VERSION
k8s-master    Ready      control-plane   425d   v1.24.1
k8s-worker1   NotReady   <none>          425d   v1.24.1
k8s-worker2   NotReady   <none>          425d   v1.24.1

同时在worker节点上查看kubelet状态,不是active状态,经过试验,发现调整了worker节点的时间,前置2个月,kubelet状态就正常了。
判定是worker节点没有更新证书。

在worker节点上执行:

kubeadm certs renew all

并不能解决问题。

但问题已经聚焦,在是证书过期问题没有解决。

于是考虑在master节点上,生成worker节点的kubelet.conf文件,复制过去。具体操作如下:

root@k8s-master:/home/kiosk# kubeadm init phase kubeconfig kubelet --node-name k8s-worker1 --config ./kubeadm-config.yaml --kubeconfig-dir /home/kiosk/tmp    
[kubeconfig] Writing "kubelet.conf" kubeconfig file

解释一下:

  • --node-name k8s-worker1是指定worker节点,
  • --config ./kubeadm-config.yaml,这个需要到集群创建时,使用的kubeadm-config.yaml文件所在位置
  • --kubeconfig-dir /home/kiosk/tmp 意思是生成一个配置文件到tmp目录下,并不是初始化集群

接着拷贝到worker1节点:

root@k8s-master:/home/kiosk/tmp# scp ./kubelet.conf 192.168.147.129:/etc/kubernetes/

在worker1节点上查看:

root@k8s-worker1:/etc/kubernetes# systemctl restart kubelet
//重启下服务
root@k8s-worker1:/etc/kubernetes# ls /var/lib/kubelet/pki/
kubelet-client-2022-08-16-12-45-49.pem  kubelet-client-2023-10-15-16-13-31.pem  kubelet-client-current.pem  kubelet.crt  kubelet.key
root@k8s-worker1:/etc/kubernetes# ll  /var/lib/kubelet/pki/  
total 24
drwxr-xr-x 2 root root 4096 Oct 15 16:13 ./
drwxr-xr-x 8 root root 4096 Aug 16  2022 ../
-rw------- 1 root root 1118 Aug 16  2022 kubelet-client-2022-08-16-12-45-49.pem
-rw------- 1 root root 1114 Oct 15 16:13 kubelet-client-2023-10-15-16-13-31.pem
lrwxrwxrwx 1 root root   59 Oct 15 16:13 kubelet-client-current.pem -> /var/lib/kubelet/pki/kubelet-client-2023-10-15-16-13-31.pem
## 链接到新pem文件了
-rw-r--r-- 1 root root 2271 Aug 16  2022 kubelet.crt
-rw------- 1 root root 1679 Aug 16  2022 kubelet.key
## 查看证书
root@k8s-worker1:/etc/kubernetes# openssl x509 -in /var/lib/kubelet/pki/kubelet-client-current.pem -noout -text  |grep Not
            Not Before: Oct 15 16:08:31 2023 GMT
            Not After : Oct 14 16:08:31 2024 GMT

再次查看kubelet服务:

root@k8s-worker1:/etc/kubernetes# systemctl status kubelet
● kubelet.service - kubelet: The Kubernetes Node Agent
     Loaded: loaded (/lib/systemd/system/kubelet.service; enabled; vendor preset: enabled)
    Drop-In: /etc/systemd/system/kubelet.service.d
             └─10-kubeadm.conf
     Active: active (running) since Sun 2023-10-15 16:13:56 UTC; 14min ago
       Docs: https://kubernetes.io/docs/home/
   Main PID: 6413 (kubelet)
      Tasks: 15 (limit: 4534)
     Memory: 37.7M
        CPU: 26.264s

在master节点上查看:

root@k8s-master:/home/kiosk/tmp# k get nodes
NAME          STATUS     ROLES           AGE    VERSION
k8s-master    Ready      control-plane   425d   v1.24.1
k8s-worker1   Ready      <none>          425d   v1.24.1
k8s-worker2   NotReady   <none>          425d   v1.24.1

同理,操作worker2节点。

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
目录
相关文章
|
Kubernetes 容器 Perl
kubeadm初始化k8s集群延长证书过期时间
kubeadm初始化k8s集群延长证书过期时间
|
8月前
|
Prometheus 监控 Kubernetes
监控 Kubernetes 集群证书过期时间的三种方案
监控 Kubernetes 集群证书过期时间的三种方案
|
8月前
|
Kubernetes Linux 调度
K8S证书过期解决办法之替换证书
K8S证书过期解决办法之替换证书
1249 0
|
Kubernetes 测试技术 API
Kubernetes 证书过期怎么玩
Kubernetes 证书过期怎么玩
366 1
|
8天前
|
Prometheus Kubernetes 监控
OpenAI故障复盘 - 阿里云容器服务与可观测产品如何保障大规模K8s集群稳定性
聚焦近日OpenAI的大规模K8s集群故障,介绍阿里云容器服务与可观测团队在大规模K8s场景下我们的建设与沉淀。以及分享对类似故障问题的应对方案:包括在K8s和Prometheus的高可用架构设计方面、事前事后的稳定性保障体系方面。
|
5天前
|
Kubernetes Ubuntu 网络安全
ubuntu使用kubeadm搭建k8s集群
通过以上步骤,您可以在 Ubuntu 系统上使用 kubeadm 成功搭建一个 Kubernetes 集群。本文详细介绍了从环境准备、安装 Kubernetes 组件、初始化集群到管理和使用集群的完整过程,希望对您有所帮助。在实际应用中,您可以根据具体需求调整配置,进一步优化集群性能和安全性。
38 12
|
10天前
|
Kubernetes 网络协议 应用服务中间件
Kubernetes Ingress:灵活的集群外部网络访问的利器
《Kubernetes Ingress:集群外部访问的利器-打造灵活的集群网络》介绍了如何通过Ingress实现Kubernetes集群的外部访问。前提条件是已拥有Kubernetes集群并安装了kubectl工具。文章详细讲解了Ingress的基本组成(Ingress Controller和资源对象),选择合适的版本,以及具体的安装步骤,如下载配置文件、部署Nginx Ingress Controller等。此外,还提供了常见问题的解决方案,例如镜像下载失败的应对措施。最后,通过部署示例应用展示了Ingress的实际使用方法。
28 2
|
22天前
|
存储 Kubernetes 关系型数据库
阿里云ACK备份中心,K8s集群业务应用数据的一站式灾备方案
本文源自2024云栖大会苏雅诗的演讲,探讨了K8s集群业务为何需要灾备及其重要性。文中强调了集群与业务高可用配置对稳定性的重要性,并指出人为误操作等风险,建议实施周期性和特定情况下的灾备措施。针对容器化业务,提出了灾备的新特性与需求,包括工作负载为核心、云资源信息的备份,以及有状态应用的数据保护。介绍了ACK推出的备份中心解决方案,支持命名空间、标签、资源类型等维度的备份,并具备存储卷数据保护功能,能够满足GitOps流程企业的特定需求。此外,还详细描述了备份中心的使用流程、控制台展示、灾备难点及解决方案等内容,展示了备份中心如何有效应对K8s集群资源和存储卷数据的灾备挑战。
|
2月前
|
Kubernetes 监控 Cloud Native
Kubernetes集群的高可用性与伸缩性实践
Kubernetes集群的高可用性与伸缩性实践
78 1
|
3月前
|
JSON Kubernetes 容灾
ACK One应用分发上线:高效管理多集群应用
ACK One应用分发上线,主要介绍了新能力的使用场景

相关产品

  • 容器服务Kubernetes版