10.10. 手动创建安装配置文件
安装集群要求您手动创建安装配置文件。
先决条件
- 在本地机器上有一个 SSH 公钥用于安装程序。您可以使用密钥在集群节点上进行 SSH 身份验证,以进行调试和灾难恢复。
- 已获取 OpenShift Container Platform 安装程序和集群的 pull secret。
流程
- 创建一个安装目录来存储所需的安装资产: - mkdir <installation_directory> - $ mkdir <installation_directory>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 重要- 您必须创建一个目录。有些安装资产,如 bootstrap X.509 证书的过期间隔较短,因此不得重复使用安装目录。如果要重复使用另一个集群安装中的单个文件,您可以将它们复制到您的目录中。但是,安装资产的文件名可能会在发行版本间有所变化。从以前的 OpenShift Container Platform 版本中复制安装文件时请小心。 
- 对提供的 - install-config.yaml文件模板示例进行自定义,并将文件保存到- <installation_directory>中。注意- 此配置文件必须命名为 - install-config.yaml。
- 备份 - install-config.yaml文件,以便使用它来安装多个集群。重要- 现在备份 - install-config.yaml文件,因为安装过程会在下一步中消耗该文件。
10.10.1. 安装配置参数
					在部署 OpenShift Container Platform 集群前,您可以提供参数值来描述托管集群的云平台中的帐户,并选择性地自定义集群平台。在创建 install-config.yaml 安装配置文件时,您可以通过命令行为所需参数提供值。如果自定义集群,您可以修改 install-config.yaml 文件以提供有关平台的更多详情。
				
						安装后,您无法在 install-config.yaml 文件中修改这些参数。
					
10.10.1.1. 所需的配置参数
下表描述了所需的安装配置参数:
| 参数 | 描述 | 值 | 
|---|---|---|
| 
										 | 
										 | 字符串 | 
| 
										 | 
										云供应商的基域。基域用于创建到 OpenShift Container Platform 集群组件的路由。集群的完整 DNS 名称是  | 
										完全限定域名或子域名,如  | 
| 
										 | 
										Kubernetes 资源  | 对象 | 
| 
										 | 
										集群的名称。集群的 DNS 记录是  | 
										小写字母、连字符( | 
| 
										 | 
										要执行安装的具体平台配置:  | 对象 | 
| 
										 | 从 Red Hat OpenShift Cluster Manager 获取 pull secret,验证从 Quay.io 等服务中下载 OpenShift Container Platform 组件的容器镜像。 |  | 
10.10.1.2. 网络配置参数
您可以根据现有网络基础架构的要求自定义安装配置。例如,您可以扩展集群网络的 IP 地址块,或者提供不同于默认值的不同 IP 地址块。
仅支持 IPv4 地址。
Red Hat OpenShift Data Foundation 灾难恢复解决方案不支持 Globalnet。对于区域灾难恢复场景,请确保为每个集群中的集群和服务网络使用非重叠的专用 IP 地址。
| 参数 | 描述 | 值 | 
|---|---|---|
| 
										 | 集群网络的配置。 | 对象 注意 
											您无法在安装后修改  | 
| 
										 | 要安装的 Red Hat OpenShift Networking 网络插件。 | 
										 | 
| 
										 | pod 的 IP 地址块。 
										默认值为  如果您指定了多个 IP 地址块,块不得重叠。 | 对象数组。例如: networking:
  clusterNetwork:
  - cidr: 10.128.0.0/14
    hostPrefix: 23 | 
| 
										 | 
										使用  IPv4 网络。 | 
										无类别域间路由(CIDR)表示法中的 IP 地址块。IPv4 块的前缀长度介于  | 
| 
										 | 
										分配给每个节点的子网前缀长度。例如,如果  | 子网前缀。 
										默认值为  | 
| 
										 | 
										服务的 IP 地址块。默认值为  OpenShift SDN 和 OVN-Kubernetes 网络插件只支持服务网络的一个 IP 地址块。 | CIDR 格式具有 IP 地址块的数组。例如: networking: serviceNetwork: - 172.30.0.0/16  | 
| 
										 | 机器的 IP 地址块。 如果您指定了多个 IP 地址块,块不得重叠。 | 对象数组。例如: networking: machineNetwork: - cidr: 10.0.0.0/16  | 
| 
										 | 
										使用  | CIDR 表示法中的 IP 网络块。 
										例如:  注意 
											将  | 
10.10.1.3. 可选的配置参数
下表描述了可选的安装配置参数:
| 参数 | 描述 | 值 | 
|---|---|---|
| 
										 | 添加到节点可信证书存储中的 PEM 编码 X.509 证书捆绑包。配置了代理时,也可以使用此信任捆绑包。 | 字符串 | 
| 
										 | 控制可选核心组件的安装。您可以通过禁用可选组件来减少 OpenShift Container Platform 集群的空间。如需更多信息,请参阅安装中的"集群功能"页面。 | 字符串数组 | 
| 
										 | 
										选择要启用的一组初始可选功能。有效值为  | 字符串 | 
| 
										 | 
										将可选功能集合扩展到您在  | 字符串数组 | 
| 
										 | 组成计算节点的机器的配置。 | 
										 | 
| 
										 | 
										决定池中机器的指令集合架构。目前,不支持具有不同架构的集群。所有池都必须指定相同的架构。有效值为  | 字符串 | 
| 
										 | 
										是否在计算机器上启用或禁用并发多  重要 如果您禁用并发多线程,请确保您的容量规划考虑机器性能显著降低的情况。 | 
										 | 
| 
										 | 
										使用  | 
										 | 
| 
										 | 
										使用  | 
										 | 
| 
										 | 要置备的计算机器数量,也称为 worker 机器。 | 
										大于或等于  | 
| 
										 | 为功能集启用集群。功能集是 OpenShift Container Platform 功能的集合,默认情况下不启用。有关在安装过程中启用功能集的更多信息,请参阅"使用功能门启用功能"。 | 
										字符串.要启用的功能集的名称,如  | 
| 
										 | 组成 control plane 的机器的配置。 | 
										 | 
| 
										 | 
										决定池中机器的指令集合架构。目前,不支持具有不同架构的集群。所有池都必须指定相同的架构。有效值为  | 字符串 | 
| 
										 | 
										是否在 control plane 机器上启用或禁用并发多  重要 如果您禁用并发多线程,请确保您的容量规划考虑机器性能显著降低的情况。 | 
										 | 
| 
										 | 
										使用  | 
										 | 
| 
										 | 
										使用  | 
										 | 
| 
										 | 要置备的 control plane 机器数量。 | 
										唯一支持的值是  | 
| 
										 | Cloud Credential Operator(CCO)模式。如果没有指定模式,CCO 会动态尝试决定提供的凭证的功能,在支持多个模式的平台上首选 mint 模式。 注意 不是所有 CCO 模式都支持所有云供应商。如需有关 CCO 模式的更多信息,请参阅集群 Operator 参考内容中的 Cloud Credential Operator 条目。 注意 
											如果您的 AWS 帐户启用了服务控制策略 (SCP),您必须将  | 
										 | 
| 
										 | 
										启用或禁用 FIPS 模式。默认值为  重要 
											要为集群启用 FIPS 模式,您必须从配置为以 FIPS 模式操作的 Red Hat Enterprise Linux (RHEL) 计算机运行安装程序。有关在 RHEL 中配置 FIPS 模式的更多信息,请参阅在 FIPS 模式中安装该系统。只有在  注意 如果使用 Azure File 存储,则无法启用 FIPS 模式。 | 
										 | 
| 
										 | release-image 内容的源和存储库。 | 
										对象数组。包括一个  | 
| 
										 | 
										使用  | 字符串 | 
| 
										 | 指定可能还包含同一镜像的一个或多个仓库。 | 字符串数组 | 
| 
										 | 
										在 AWS 中设置 NLB 负载均衡器类型需要此项。有效值为  | 
										 | 
| 
										 | 如何发布或公开集群的面向用户的端点,如 Kubernetes API、OpenShift 路由。 | 
										 | 
| 
										 | 用于验证对集群机器的访问的 SSH 密钥。 注意 
											对于您要在其上执行安装调试或灾难恢复的生产环境 OpenShift Container Platform 集群,请指定  | 
										例如, | 
10.10.1.4. 可选的 AWS 配置参数
下表描述了可选的 AWS 配置参数:
| 参数 | 描述 | 值 | 
|---|---|---|
| 
										 | 用于为集群引导计算机器的 AWS AMI。对于需要自定义 RHCOS AMI 的区域来说,这是必需的。 | 属于集合 AWS 区域的任何已发布或自定义 RHCOS AMI。如需可用的 AMI ID,请参阅 RHCOS AMIs for AWS infrastructure。 | 
| 
										 | 一个已存在的 AWS IAM 角色应用到计算机器池实例配置集。您可以使用这些字段与命名方案匹配,并为您的 IAM 角色包含预定义的权限界限。如果未定义,安装程序会创建一个新的 IAM 角色。 | 有效 AWS IAM 角色的名称。 | 
| 
										 | 为根卷保留的每秒输入/输出操作 (IOPS) 数。 | 
										整数,如  | 
| 
										 | 以 GiB 为单位的根卷大小。 | 
										整数,如  | 
| 
										 | 根卷的类型。 | 
										有效的 AWS EBS 卷类型,如  | 
| 
										 | KMS 密钥的 Amazon 资源名称(密钥 ARN)。这需要使用特定的 KMS 密钥加密 worker 节点的操作系统卷。 | 有效的 密钥 ID 或密钥 ARN。 | 
| 
										 | 计算机器的 EC2 实例类型。 | 
										有效的 AWS 实例类型,如  | 
| 
										 | 安装程序在其中为计算机机器池创建机器的可用区。如果您提供自己的 VPC,则必须在那个可用域中提供一个子网。 | 
										有效 AWS 可用区的列表,如  | 
| 
										 | 用于为集群引导 control plane 机器的 AWS AMI。对于需要自定义 RHCOS AMI 的区域来说,这是必需的。 | 属于集合 AWS 区域的任何已发布或自定义 RHCOS AMI。如需可用的 AMI ID,请参阅 RHCOS AMIs for AWS infrastructure。 | 
| 
										 | 应用到 control plane 机器池实例配置集的已存在的 AWS IAM 角色。您可以使用这些字段与命名方案匹配,并为您的 IAM 角色包含预定义的权限界限。如果未定义,安装程序会创建一个新的 IAM 角色。 | 有效 AWS IAM 角色的名称。 | 
| 
										 | KMS 密钥的 Amazon 资源名称(密钥 ARN)。这需要使用特定的 KMS 密钥加密 control plane 节点的操作系统卷。 | 有效的密钥 ID 和密钥 ARN。 | 
| 
										 | control plane 机器的 EC2 实例类型。 | 
										有效的 AWS 实例类型,如  | 
| 
										 | 安装程序在其中为 control plane 机器池创建机器的可用区。 | 
										有效 AWS 可用区的列表,如  | 
| 
										 | 用于为集群引导所有机器的 AWS AMI。如果设置,AMI 必须属于与集群相同的区域。对于需要自定义 RHCOS AMI 的区域来说,这是必需的。 | 属于集合 AWS 区域的任何已发布或自定义 RHCOS AMI。如需可用的 AMI ID,请参阅 RHCOS AMIs for AWS infrastructure。 | 
| 
										 | 集群的现有 Route 53 私有托管区。您只能在提供自己的 VPC 时使用已存在的托管区。安装前,托管区必须已经与用户提供的 VPC 关联。另外,托管区的域必须是集群域或集群域的父域。如果未定义,安装程序会创建一个新的托管区。 | 
										字符串,如  | 
| 
										 | AWS 服务端点名称。只有在必须使用替代 AWS 端点(如 FIPS)时,才需要自定义端点。可以为 EC2、S3、IAM、Elastic Load Balancing、Tagging、Route 53 和 STS AWS 服务指定自定义 API 端点。 | 有效的 AWS 服务端点名称。 | 
| 
										 | 安装程序在其中创建所有集群资源的 AWS 区域。 | 
										任何有效的 AWS 区域,如  aws ec2 describe-instance-type-offerings --filters Name=instance-type,Values=c7g.xlarge 重要 在基于 ARM 的 AWS 实例上运行时,请确保进入 AWS Graviton 处理器可用的区域。请参阅 AWS 文档中的全局可用性 映射。目前,只有一些区域才提供 AWS Graviton3 处理器。 | 
| 
										 | 
										AWS 服务端点 URL。URL 必须使用  | 有效的 AWS 服务端点 URL。 | 
| 
										 | 键与值的映射,安装程序将其作为标签添加到它所创建的所有资源。 | 
										任何有效的 YAML 映射,如  注意 您可以在安装过程中最多添加 25 个用户定义的标签。剩余的 25 个标签是为 OpenShift Container Platform 保留的。 | 
| 
										 | 指示集群 Operator 中的标记,在 Operator 创建的 AWS 资源标签中包含指定的用户标签。 | 
										布尔值,如  | 
| 
										 | 
										如果您提供 VPC,而不是让安装程序为您创建 VPC,请指定要使用的集群子网。子网必须是您指定的同一  | 有效的子网 ID。 | 
10.10.2. 集群安装的最低资源要求
每台集群机器都必须满足以下最低要求:
| 机器 | 操作系统 | vCPU [1] | 虚拟内存 | Storage | 每秒输入/输出 (IOPS) [2] | 
|---|---|---|---|---|---|
| bootstrap | RHCOS | 4 | 16 GB | 100 GB | 300 | 
| Control plane(控制平面) | RHCOS | 4 | 16 GB | 100 GB | 300 | 
| Compute | RHCOS、RHEL 8.6 及更新版本 [3] | 2 | 8 GB | 100 GB | 300 | 
- 当未启用并发多线程(SMT)或超线程时,一个 vCPU 相当于一个物理内核。启用后,使用以下公式来计算对应的比例:(每个内核数的线程)× sockets = vCPU。
- OpenShift Container Platform 和 Kubernetes 对磁盘性能非常敏感,建议使用更快的存储速度,特别是 control plane 节点上需要 10 ms p99 fsync 持续时间的 etcd。请注意,在许多云平台上,存储大小和 IOPS 可一起扩展,因此您可能需要过度分配存储卷来获取足够的性能。
- 与所有用户置备的安装一样,如果您选择在集群中使用 RHEL 计算机器,则负责所有操作系统生命周期管理和维护,包括执行系统更新、应用补丁和完成所有其他必要的任务。RHEL 7 计算机器的使用已弃用,并已在 OpenShift Container Platform 4.10 及更新的版本中删除。
如果平台的实例类型满足集群机器的最低要求,则 OpenShift Container Platform 支持使用它。
10.10.3. 为 AWS 测试的实例类型
以下 Amazon Web Services(AWS) 实例类型已经过 OpenShift Container Platform 测试。
将以下图中包含的机器类型用于 AWS 实例。如果您使用没有在图中列出的实例类型,请确保使用的实例大小与集群安装"最小资源要求"中列出的最少资源要求匹配。
例 10.1. 基于 64 位 x86 架构的机器类型
- 
								c4.*
- 
								c5.*
- 
								c5a.*
- 
								i3.*
- 
								m4.*
- 
								m5.*
- 
								m5a.*
- 
								m6a.*
- 
								m6i.*
- 
								r4.*
- 
								r5.*
- 
								r5a.*
- 
								r6i.*
- 
								t3.*
- 
								t3a.*
10.10.4. 在 64 位 ARM 基础架构上为 AWS 测试过的实例类型
OpenShift Container Platform 中已经测试了以下 Amazon Web Services (AWS) ARM64 实例类型。
使用 AWS ARM 实例的以下图中包含的机器类型。如果您使用没有在图中列出的实例类型,请确保使用的实例大小与集群安装"最小资源要求"中列出的最少资源要求匹配。
例 10.2. 基于 64 位 ARM 架构的机器类型
- 
								c6g.*
- 
								c7g.*
- 
								m6g.*
- 
								m7g.*
- 
								r8g.*
10.10.5. AWS 的自定义 install-config.yaml 文件示例
					您可以自定义安装配置文件 (install-config.yaml),以指定有关 OpenShift Container Platform 集群平台的更多详细信息,或修改所需参数的值。
				
此示例 YAML 文件仅供参考。使用它作为资源,在您手动创建的安装配置文件中输入参数值。
- 1 12 14 23
- 必需。
- 2
- 可选:添加此参数来强制 Cloud Credential Operator(CCO)使用指定的模式,而不是让 CCO 动态尝试决定凭证的功能。如需有关 CCO 模式的详情,请参阅 Red Hat Operator 参考内容中的 Cloud Credential Operator 条目。
- 3 8 15
- 如果没有提供这些参数和值,安装程序会提供默认值。
- 4
- controlPlane部分是一个单个映射,但- compute部分是一系列映射。为满足不同数据结构的要求,- compute部分的第一行必须以连字符- -开头,controlPlane- 部分的第一行则不以连字符开头。仅使用一个 control plane 池。
- 5 9
- 是否要启用或禁用并发多线程或超线程。默认情况下,启用并发多线程以提高机器内核的性能。您可以通过将 参数值设置为Disabled来禁用它。如果在某些集群机器中禁用并发多线程,则必须在所有集群机器中禁用它。重要如果您禁用并发多线程,请确保您的容量规划考虑机器性能显著降低的情况。如果您对机器禁用并发多线程,请使用较大的实例类型,如 m4.2xlarge或m5.2xlarge。
- 6 10
- 要为 etcd 配置更快的存储,特别是对于较大的集群,请将存储类型设置为io1,并将iops设为2000。
- 7 11
- 是否需要 Amazon EC2 实例元数据服务 v2 (IMDSv2)。为了要求 IMDSv2,请将参数值设置为Required。要允许使用 IMDSv1 和 IMDSv2,请将参数值设置为Optional。如果没有指定值,则允许 IMDSv1 和 IMDSv2。注意在集群安装过程中设置的 control plane 机器的 IMDS 配置只能使用 AWS CLI 更改。可以使用计算机器集来更改计算机器的 IMDS 配置。 
- 13
- 要安装的集群网络插件。支持的值有OVNKubernetes和OpenShiftSDN。默认值为OVNKubernetes。
- 16
- 如果您提供自己的 VPC,为集群使用的每个可用区指定子网。
- 17
- 用于为集群引导机器的 AMI ID。如果设置,AMI 必须属于与集群相同的区域。
- 18
- AWS 服务端点。在安装到未知 AWS 区域时,需要自定义端点。端点 URL 必须使用https协议,主机必须信任该证书。
- 19
- 您现有 Route 53 私有托管区的 ID。提供现有的托管区需要您提供自己的 VPC,托管区已在安装集群前与 VPC 关联。如果未定义,安装程序会创建一个新的托管区。
- 20
- 是否启用或禁用 FIPS 模式。默认情况下不启用 FIPS 模式。如果启用了 FIPS 模式,运行 OpenShift Container Platform 的 Red Hat Enterprise Linux CoreOS(RHCOS)机器会绕过默认的 Kubernetes 加密套件,并使用由 RHCOS 提供的加密模块。重要要为集群启用 FIPS 模式,您必须从配置为以 FIPS 模式操作的 Red Hat Enterprise Linux (RHEL) 计算机运行安装程序。有关在 RHEL 中配置 FIPS 模式的更多信息,请参阅在 FIPS 模式中安装该系统。只有在 x86_64、ppc64le和s390x架构的 OpenShift Container Platform 部署中才支持使用 FIPS 验证的或Modules In Process 加密库。
- 21
- 您可以选择提供您用来访问集群中机器的sshKey值。注意对于您要在其上执行安装调试或灾难恢复的生产环境 OpenShift Container Platform 集群,请指定 ssh-agent进程使用的 SSH 密钥。
- 22
- 如何发布集群的面向用户的端点。将publish设置为Internal以部署一个私有集群,它不能被互联网访问。默认值为External。
10.10.6. 在安装过程中配置集群范围的代理
					生产环境可能会拒绝直接访问互联网,而是提供 HTTP 或 HTTPS 代理。您可以通过在 install-config.yaml 文件中配置代理设置,将新的 OpenShift Container Platform 集群配置为使用代理。
				
先决条件
- 
							您有一个现有的 install-config.yaml文件。
- 您检查了集群需要访问的站点,并确定它们中的任何站点是否需要绕过代理。默认情况下,所有集群出口流量都经过代理,包括对托管云供应商 API 的调用。如果需要,您将在 - Proxy 对象的- spec.noProxy字段中添加站点来绕过代理。注意- Proxy对象- status.noProxy字段使用安装配置中的- networking.machineNetwork[].cidr、- networking.clusterNetwork[].cidr和- networking.serviceNetwork[]字段的值填充。- 对于在 Amazon Web Services(AWS)、Google Cloud Platform(GCP)、Microsoft Azure 和 Red Hat OpenStack Platform(RHOSP)上安装, - Proxy对象- status.noProxy字段也会使用实例元数据端点填充(- 169.254.169.254)。
流程
- 编辑 - install-config.yaml文件并添加代理设置。例如:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- 用于创建集群外 HTTP 连接的代理 URL。URL 方案必须是http。
- 2
- 用于创建集群外 HTTPS 连接的代理 URL。
- 3
- 要从代理中排除的目标域名、IP 地址或其他网络 CIDR 的逗号分隔列表。在域前面加上.以仅匹配子域。例如,.y.com匹配x.y.com,但不匹配y.com。使用*绕过所有目的地的代理。如果您已将 AmazonEC2、Elastic Load Balancing和S3VPC 端点添加到 VPC 中,您必须将这些端点添加到noProxy字段。
- 4
- 如果提供,安装程序会在openshift-config命名空间中生成名为user-ca-bundle的配置映射,其包含代理 HTTPS 连接所需的一个或多个额外 CA 证书。然后,Cluster Network Operator 会创建trusted-ca-bundle配置映射,将这些内容与 Red Hat Enterprise Linux CoreOS(RHCOS)信任捆绑包合并,Proxy对象的trustedCA字段中也会引用此配置映射。additionalTrustBundle字段是必需的,除非代理的身份证书由来自 RHCOS 信任捆绑包的颁发机构签名。
- 5
- 可选:决定Proxy对象的配置以引用trustedCA字段中user-ca-bundle配置映射的策略。允许的值是Proxyonly和Always。仅在配置了http/https代理时,使用Proxyonly引用user-ca-bundle配置映射。使用Always始终引用user-ca-bundle配置映射。默认值为Proxyonly。
 注意- 安装程序不支持代理的 - readinessEndpoints字段。注意- 如果安装程序超时,重启并使用安装程序的 - wait-for命令完成部署。例如:- ./openshift-install wait-for install-complete --log-level debug - $ ./openshift-install wait-for install-complete --log-level debug- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 保存该文件并在安装 OpenShift Container Platform 时引用。
					安装程序会创建一个名为 cluster 的集群范围代理,该代理 使用 提供的 install-config.yaml 文件中的代理设置。如果没有提供代理设置,仍然会创建一个 cluster Proxy 对象,但它会有一个空 spec。
				
						只支持名为 cluster 的 Proxy 对象,且无法创建额外的代理。