为 kubelet 配置证书轮换
特性状态:
- 要求 Kubernetes 1.8.0 或更高的版本
Kubelet 使用证书进行 Kubernetes API 的认证。 默认情况下,这些证书的签发期限为一年,所以不需要太频繁地进行更新。
kubelet
进程接收 --rotate-certificates
参数,该参数决定 kubelet 在当前使用的 证书即将到期时,是否会自动申请新的证书。
进程接收 --cluster-signing-duration
参数 (在 1.19 版本之前为 --experimental-cluster-signing-duration
),用来 控制签发证书的有效期限。
最初,来自节点上 kubelet 的证书签名请求处于 Pending
状态。 如果证书签名请求满足特定条件, 控制器管理器会自动批准,此时请求会处于 Approved
状态。 接下来,控制器管理器会签署证书, 证书的有效期限由 参数指定,签署的证书会被附加到证书签名请求中。
Kubelet 会从 Kubernetes API 取回签署的证书,并将其写入磁盘,存储位置通过 --cert-dir
参数指定。 然后 kubelet 会使用新的证书连接到 Kubernetes API。