21.2. 安全路由
安全路由提供以下几种 TLS 终止功能来为客户端提供证书。以下小节介绍了如何使用自定义证书创建重新加密、边缘和透传路由。
如果您在 Microsoft Azure 中创建通过公共端点的路由,则资源名称会受到限制。您不能创建使用某些词语的资源。如需 Azure 限制词语的列表,请参阅 Azure 文档中的解决预留资源名称错误。
21.2.1. 使用自定义证书创建重新加密路由
					您可以通过 oc create route 命令,使用重新加密 TLS 终止和自定义证书配置安全路由。
				
前提条件
- 您必须在 PEM 编码文件中有一个证书/密钥对,其中的证书对路由主机有效。
- 您可以在 PEM 编码文件中有一个单独的 CA 证书来补全证书链。
- 您必须在 PEM 编码文件中有单独的目标 CA 证书。
- 您必须具有要公开的服务。
不支持密码保护的密钥文件。要从密钥文件中删除密码,使用以下命令:
openssl rsa -in password_protected_tls.key -out tls.key
$ openssl rsa -in password_protected_tls.key -out tls.key流程
						此流程使用自定义证书和重新加密 TLS 终止创建 Route 资源。以下步骤假定证书/密钥对位于当前工作目录下的 tls.crt 和 tls.key 文件中。您还必须指定一个目标 CA 证书,使 Ingress Controller 信任服务的证书。您也可以根据需要指定 CA 证书来补全证书链。替换 tls.crt、tls.key、cacert.crt 和(可选)ca.crt 的实际路径名称。替换您要为 frontend 公开的 Service 资源的名称。使用适当的主机名替换 www.example.com。
					
- 使用重新加密 TLS 终止和自定义证书,创建安全 - Route资源:- oc create route reencrypt --service=frontend --cert=tls.crt --key=tls.key --dest-ca-cert=destca.crt --ca-cert=ca.crt --hostname=www.example.com - $ oc create route reencrypt --service=frontend --cert=tls.crt --key=tls.key --dest-ca-cert=destca.crt --ca-cert=ca.crt --hostname=www.example.com- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 如果您检查生成的 - Route资源,它应该类似于如下:- 安全路由 YAML 定义 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 如需了解更多选项,请参阅 - oc create route reencrypt --help。
21.2.2. 使用自定义证书创建边缘路由
					您可以通过 oc create route 命令,使用边缘 TLS 终止和自定义证书配置安全路由。使用边缘路由时,Ingress Controller 在将流量转发到目标 pod 之前终止 TLS 加密。该路由指定了 Ingress Controller 用于路由的 TLS 证书和密钥。
				
前提条件
- 您必须在 PEM 编码文件中有一个证书/密钥对,其中的证书对路由主机有效。
- 您可以在 PEM 编码文件中有一个单独的 CA 证书来补全证书链。
- 您必须具有要公开的服务。
不支持密码保护的密钥文件。要从密钥文件中删除密码,使用以下命令:
openssl rsa -in password_protected_tls.key -out tls.key
$ openssl rsa -in password_protected_tls.key -out tls.key流程
						此流程使用自定义证书和边缘 TLS 终止创建 Route 资源。以下步骤假定证书/密钥对位于当前工作目录下的 tls.crt 和 tls.key 文件中。您也可以根据需要指定 CA 证书来补全证书链。替换 tls.crt、tls.key 和(可选)ca.crt 的实际路径名称。替换您要为 frontend 公开的服务名称。使用适当的主机名替换 www.example.com。
					
- 使用边缘 TLS 终止和自定义证书,创建安全 - Route资源。- oc create route edge --service=frontend --cert=tls.crt --key=tls.key --ca-cert=ca.crt --hostname=www.example.com - $ oc create route edge --service=frontend --cert=tls.crt --key=tls.key --ca-cert=ca.crt --hostname=www.example.com- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 如果您检查生成的 - Route资源,它应该类似于如下:- 安全路由 YAML 定义 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 如需了解更多选项,请参阅 - oc create route edge --help。
21.2.3. 创建 passthrough 路由
					您可以使用 oc create route 命令使用 passthrough 终止配置安全路由。如果 passthrough 终止,加密的流量会直接发送到目的地,而路由器不会提供 TLS 终止。因此,路由不需要密钥或证书。
				
前提条件
- 您必须具有要公开的服务。
流程
- 创建 - Route资源:- oc create route passthrough route-passthrough-secured --service=frontend --port=8080 - $ oc create route passthrough route-passthrough-secured --service=frontend --port=8080- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 如果您检查生成的 - Route资源,它应该类似于如下:- 使用 Passthrough 终止的安全路由 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 目标 pod 负责为端点上的流量提供证书。目前,这是唯一支持需要客户端证书的方法,也称双向验证。 
21.2.4. 使用外部受管证书创建路由
在 TLS secret 中使用外部证书保护路由只是一个技术预览功能。技术预览功能不受红帽产品服务等级协议(SLA)支持,且功能可能并不完整。红帽不推荐在生产环境中使用它们。这些技术预览功能可以使用户提早试用新的功能,并有机会在开发阶段提供反馈意见。
有关红帽技术预览功能支持范围的更多信息,请参阅技术预览功能支持范围。
					您可以使用路由 API 的 .spec.tls.externalCertificate 字段来使用第三方证书管理解决方案配置 OpenShift Container Platform 路由。您可以通过 secret 引用外部管理的 TLS 证书,无需手动证书管理。使用外部受管证书可减少确保证书更新平稳推出的错误,使 OpenShift 路由器能够及时提供更新的证书。
				
此功能适用于边缘路由和重新加密路由。
先决条件
- 
							您必须启用 RouteExternalCertificate功能门。
- 
							您必须在 routes/custom-host上具有create和update权限。
- 
							您必须有一个包含 PEM 编码格式的有效证书/密钥对的 secret,类型为 kubernetes.io/tls,其中包括tls.key和tls.crt键。
- 您必须将引用的 secret 放在与您要保护的路由相同的命名空间中。
流程
- 运行以下命令,在与 secret 相同的命名空间中创建一个 - 角色,以允许路由器服务帐户读取访问权限:- oc create role secret-reader --verb=get,list,watch --resource=secrets --resource-name=<secret-name> \ --namespace=<current-namespace> - $ oc create role secret-reader --verb=get,list,watch --resource=secrets --resource-name=<secret-name> \- 1 - --namespace=<current-namespace>- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 运行以下命令,在与 secret 相同的命名空间中创建 - rolebinding,并将 router 服务帐户绑定到新创建的角色:- oc create rolebinding secret-reader-binding --role=secret-reader --serviceaccount=openshift-ingress:router --namespace=<current-namespace> - $ oc create rolebinding secret-reader-binding --role=secret-reader --serviceaccount=openshift-ingress:router --namespace=<current-namespace>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- 指定 secret 和路由所在的命名空间。
 
- 创建一个定义 - 路由的 YAML 文件,并使用以下示例指定包含证书的 secret。- 安全路由的 YAML 定义 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- 指定 secret 的实际名称。
 
- 运行以下命令来创建一个 - 路由资源:- oc apply -f <route.yaml> - $ oc apply -f <route.yaml>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- 指定生成的 YAML 文件名。
 
如果 secret 存在并具有证书/密钥对,如果满足所有先决条件,路由器将提供生成的证书。
						如果没有提供 .spec.tls.externalCertificate,路由器将使用默认生成的证书。
					
						使用 .spec.tls.externalCertificate 字段时,您无法提供 .spec.tls.certificate 字段或 .spec.tls.key 字段。