该kubernetes
集群位于 1.21.2。也是kubelet
1.21.2
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"}
Run Code Online (Sandbox Code Playgroud)
当我尝试“ kl get no
”时,出现以下错误
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.
Run Code Online (Sandbox Code Playgroud)
在 kubelet.crt 中,发行者如下
Subject: CN=aparapu@1591592441
Subject Public Key Info:
Public Key Algorithm: rsaEncryption
Run Code Online (Sandbox Code Playgroud)
需要帮助来更新此 kubelet.crt。
小智 10
我在许多其他论坛上看到过这个问题,最后我找到了适合我的解决方案。
首先,我的问题纯粹是由于证书造成的/var/lib/kubelet/pki/kubelet.crt
,我可以通过以下任一方式看到该证书已过期:
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
Run Code Online (Sandbox Code Playgroud)
或者
sudo openssl x509 -in /var/lib/kubelet/pki/kubelet.crt -text -noout | grep -A 2 Validity
Run Code Online (Sandbox Code Playgroud)
首先,您需要在 kubelet 中启用--rotate-certificates=true
and 。--rotate-server-certificates=true
就我而言,我使用安装了集群kubeadm
,因此我可以编辑/etc/systemd/system/kubelet.service.d/10-kubeadm.conf
,并将以下内容添加到KUBELET_EXTRA_ARGS
:
Environment="KUBELET_EXTRA_ARGS=--rotate-certificates=true --rotate-server-certificates=true --tls-cipher-suites=TLS_ECDHE_RSA_WITH_AES_128_GCM_SHA256"
Run Code Online (Sandbox Code Playgroud)
一般来说,只是将这些标志添加到 kubelet 执行中/usr/bin/kubelet --rotate-certificates=true --rotate-server-certificates=true
。
并且,使用以下命令重新加载并重新启动 kubelet:
sudo systemctl daemon-reload
sudo service kubelet restart
Run Code Online (Sandbox Code Playgroud)
重启后,我看到类似 的内容14114 log.go:172] http: TLS handshake error from 20.0.0.13:57738: no serving certificate available for the kubelet
,这表明需要添加证书并批准。
其次,我们需要批准csr
kubernetes 的(这是我以前从未见过的东西......):
kubectl get csr
Run Code Online (Sandbox Code Playgroud)
会看到证书等待批准,所以只要批准即可:
kubectl certificate approve csr-dlcf6
Run Code Online (Sandbox Code Playgroud)
您的集群现在应该已更新服务器 kubelet 证书。再次验证:
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
Run Code Online (Sandbox Code Playgroud)
一些注意事项:
/var/lib/kubelet/pki/kubelet.crt
不再使用该证书,而是/var/lib/kubelet/pki/kubelet-server-current.pem
使用符号链接并指向最新的轮换证书。参考:
归档时间: |
|
查看次数: |
6433 次 |
最近记录: |