2.4. 服务 CA 证书
用途
service-ca
是部署 OpenShift Container Platform 集群时创建自签名 CA 的一个 Operator。
过期
不支持自定义过期条件。自签名 CA 存储在一个限定名为 service-ca/signing-key
的 secret 中。它在 tls.crt
(certificate(s))、tls.key
(private key) 和 ca-bundle.crt
(CA bundle) 项中。
其他服务可通过使用 service.beta.openshift.io/serving-cert-secret-name: <secret name>
注解一个服务资源来请求一个 service serving 证书。作为响应,Operator 会为指定的 secret 生成一个新证书, tls.crt
,以及一个私钥,tls.key
。该证书的有效期为两年。
其他服务可通过使用 service.beta.openshift.io/inject-cabundle:true
注解来请求将服务 CA 的 CA 捆绑包注入 APIService 或 ConfigMap 资源,以支持通过服务 CA 生成的证书。作为响应,Operator 将其当前 CA 捆绑包写入 APIService 的 CABundle
字段,或将 service-ca.crt
写入一个 ConfigMap。
自 OpenShift Container Platform 4.3.5 起,支持自动轮转,并将其向后移植到一些 4.2.z 和 4.3.z 版本中。对于任何支持自动轮转的版本,服务 CA 证书在 26 个月内有效,并在有效期少于 13 个月时进行刷新。如果需要,您可以手动刷新服务 CA。
服务 CA 26 个月的过期时间比支持的 OpenShift Container Platform 集群的预期升级间隔更长,因此使用服务 CA 证书的非 control plane 系统将会在 CA 轮转后刷新。这会发生在轮转前使用的 CA 过期前。
手动轮换的服务 CA 不会保留对上一个服务 CA 的信任。在集群中的 Pod 重启完成前,您的服务可能会临时中断。Pod 重启可以确保 Pod 使用由新服务 CA 发布的证书服务。
管理
这些证书由系统而不是用户管理。
服务
使用服务 CA 证书的服务包括:
- cluster-autoscaler-operator
- cluster-monitoring-operator
- cluster-authentication-operator
- cluster-image-registry-operator
- cluster-ingress-operator
- cluster-kube-apiserver-operator
- cluster-kube-controller-manager-operator
- cluster-kube-scheduler-operator
- cluster-networking-operator
- cluster-openshift-apiserver-operator
- cluster-openshift-controller-manager-operator
- cluster-samples-operator
- cluster-svcat-apiserver-operator
- cluster-svcat-controller-manager-operator
- machine-config-operator
- console-operator
- insights-operator
- machine-api-operator
- operator-lifecycle-manager
这不是一个完整的列表。