首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >/var/lib/kubelet/pki/kubelet.crt已过期,如何更新?

/var/lib/kubelet/pki/kubelet.crt已过期,如何更新?
EN

Server Fault用户
提问于 2021-07-06 02:07:49
回答 1查看 3.3K关注 0票数 1

kubernetes集群位于1.21.2上。kubelet也在1.21.2上

代码语言:javascript
运行
复制
kubelet --version
Kubernetes v1.21.2

kubeadm version
kubeadm version: &version.Info{Major:"1", Minor:"21", GitVersion:"v1.21.2", GitCommit:"092fbfbf53427de67cac1e9fa54aaa09a28371d7", GitTreeState:"clean", BuildDate:"2021-06-16T12:57:56Z", GoVersion:"go1.16.5", Compiler:"gc", Platform:"linux/amd64"}

当我试图"kl get no“时,我得到了以下错误

代码语言:javascript
运行
复制
kl get no
error: You must be logged in to the server (Unauthorized)
**Note: kl is alias of kubectl**
I checked my /var/lib/kubelet/pki/kubelet.crt and it was expired.

在kubelet.crt中,发行人如下

代码语言:javascript
运行
复制
Subject: CN=aparapu@1591592441
        Subject Public Key Info:
            Public Key Algorithm: rsaEncryption

在更新此kubelet.crt时需要帮助。

EN

回答 1

Server Fault用户

发布于 2021-11-05 12:47:10

我在许多其他论坛上看到了这个问题,我终于找到了一个解决方案。

首先,我的问题完全是由于证书/var/lib/kubelet/pki/kubelet.crt造成的,我可以看到它过期了,其中之一是:

代码语言:javascript
运行
复制
echo -n | openssl s_client -connect localhost:10250 2>&1 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' | openssl x509 -text -noout | grep -A 2 Validity

代码语言:javascript
运行
复制
sudo openssl x509 -in /var/lib/kubelet/pki/kubelet.crt -text -noout  | grep -A 2 Validity

首先,您需要在kubelet中启用--rotate-certificates=true--rotate-server-certificates=true。在我的例子中,我使用kubeadm安装了集群,因此我可以编辑/etc/systemd/system/kubelet.service.d/10-kubeadm.conf,并将以下内容添加到KUBELET_EXTRA_ARGS中:

代码语言:javascript
运行
复制
Environment="KUBELET_EXTRA_ARGS=--rotate-certificates=true --rotate-server-certificates=true --tls-cipher-suites=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256"

通常,它只是将这些标志添加到kubelet /usr/bin/kubelet --rotate-certificates=true --rotate-server-certificates=true中。

然后,重新加载并重新启动kubelet,其中包括:

代码语言:javascript
运行
复制
sudo systemctl daemon-reload
sudo service kubelet restart

重新启动后,我看到类似于14114 log.go:172] http: TLS handshake error from 20.0.0.13:57738: no serving certificate available for the kubelet的内容,它指示需要添加和批准证书。

其次,我们需要批准kubernetes的csr (这是我以前从未看过的.):

代码语言:javascript
运行
复制
kubectl get csr

将看到正在等待批准的证书,因此刚刚批准:

代码语言:javascript
运行
复制
kubectl certificate approve csr-dlcf6

您的集群现在应该有服务器kubelet证书更新。再次核实:

代码语言:javascript
运行
复制
echo -n | openssl s_client -connect localhost:10250 2>&1 | sed -ne '/-BEGIN CERTIFICATE-/,/-END CERTIFICATE-/p' | openssl x509 -text -noout | grep -A 2 Validity

一些注意事项:

参考文献:

票数 7
EN
页面原文内容由Server Fault提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://serverfault.com/questions/1068751

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档