This documentation is for a release that is no longer maintained
See documentation for the latest supported version 3 or the latest supported version 4.Questo contenuto non è disponibile nella lingua selezionata.
Installing
Installing OpenShift Container Platform 4.1 clusters
Abstract
Chapter 1. Installing on AWS
1.1. Configuring an AWS account
Before you can install OpenShift Container Platform, you must configure an Amazon Web Services (AWS) account.
1.1.1. Configuring Route53
To install OpenShift Container Platform, the Amazon Web Services (AWS) account you use must have a dedicated public hosted zone in your Route53 service. This zone must be authoritative for the domain. The Route53 service provides cluster DNS resolution and name lookup for external connections to the cluster.
Procedure
- Identify your domain, or subdomain, and registrar. You can transfer an existing domain and registrar or obtain a new one through AWS or another source. Note- If you purchase a new domain through AWS, it takes time for the relevant DNS changes to propagate. For more information about purchasing domains through AWS, see Registering Domain Names Using Amazon Route 53 in the AWS documentation. 
- If you are using an existing domain and registrar, migrate its DNS to AWS. See Making Amazon Route 53 the DNS Service for an Existing Domain in the AWS documentation.
- Create a public hosted zone for your domain or subdomain. See Creating a Public Hosted Zone in the AWS documentation. - Use an appropriate root domain, such as - openshiftcorp.com, or subdomain, such as- clusters.openshiftcorp.com.
- Extract the new authoritative name servers from the hosted zone records. See Getting the Name Servers for a Public Hosted Zone in the AWS documentation.
- Update the registrar records for the AWS Route53 name servers that your domain uses. For example, if you registered your domain to a Route53 service in a different accounts, see the following topic in the AWS documentation: Adding or Changing Name Servers or Glue Records.
- If you use a subdomain, follow your company’s procedures to add its delegation records to the parent domain.
1.1.2. AWS account limits
The OpenShift Container Platform cluster uses a number of Amazon Web Services (AWS) components, and the default Service Limits affect your ability to install OpenShift Container Platform clusters. If you use certain cluster configurations, deploy your cluster in certain AWS regions, or run multiple clusters from your account, you might need to request additional resources for you AWS account.
The following table summarizes the AWS components whose limits can impact your ability to install and run OpenShift Container Platform clusters.
| Component | Number of clusters available by default | Default AWS limit | Description | 
|---|---|---|---|
| Instance Limits | Varies | Varies | By default, each cluster creates the following instances: 
 These instance type counts are within a new account’s default limit. To deploy more worker nodes, enable autoscaling, deploy large workloads, or use a different instance type, review your account limits to ensure that your cluster can deploy the machines that you need. 
									In most regions, the bootstrap and worker machines uses an  | 
| Elastic IPs (EIPs) | 0 to 1 | 5 EIPs per account | To provision the cluster in a highly available configuration, the installation program creates a public and private subnet for each availability zone within a region. Each private subnet requires a NAT Gateway, and each NAT gateway requires a separate elastic IP. Review the AWS region map to determine how many availability zones are in each region. To take advantage of the default high availability, install the cluster in a region with at least three availability zones. To install a cluster in a region with more than five availability zones, you must increase the EIP limit. Important 
										To use the  | 
| Virtual Private Clouds (VPCs) | 5 | 5 VPCs per region | Each cluster creates its own VPC. | 
| Elastic Load Balancing (ELB/NLB) | 3 | 20 per region | By default, each cluster creates an internal and external network load balancers for the master API server and a single classic elastic load balancer for the router. Deploying more Kubernetes LoadBalancer Service objects will create additional load balancers. | 
| NAT Gateways | 5 | 5 per availability zone | The cluster deploys one NAT gateway in each availability zone. | 
| Elastic Network Interfaces (ENIs) | At least 12 | 350 per region | 
									The default installation creates 21 ENIs and an ENI for each availability zone in your region. For example, the  Additional ENIs are created for additional machines and elastic load balancers that are created by cluster usage and deployed workloads. | 
| VPC Gateway | 20 | 20 per account | Your AWS account uses VPC Gateways for S3 access. Each cluster creates a single VPC Gateway for S3 access. | 
| S3 buckets | 99 | 100 buckets per account | Because the installation process creates a temporary bucket and the registry component in each cluster creates a bucket, you can create only 99 OpenShift Container Platform clusters per AWS account. | 
| Security Groups | 250 | 2,500 per account | Each cluster creates 10 distinct security groups. | 
1.1.3. Required AWS permissions
					When you attach the AdministratorAccess policy to the IAM user that you create, you grant that user all of the required permissions. To deploy an OpenShift Container Platform cluster, the IAM user requires the following permissions:
				
Required EC2 permissions for installation
- 
							ec2:AllocateAddress
- 
							ec2:AssociateAddress
- 
							ec2:AssociateDhcpOptions
- 
							ec2:AssociateRouteTable
- 
							ec2:AttachInternetGateway
- 
							ec2:AuthorizeSecurityGroupEgress
- 
							ec2:AuthorizeSecurityGroupIngress
- 
							ec2:CopyImage
- 
							ec2:CreateDhcpOptions
- 
							ec2:CreateInternetGateway
- 
							ec2:CreateNatGateway
- 
							ec2:CreateRoute
- 
							ec2:CreateRouteTable
- 
							ec2:CreateSecurityGroup
- 
							ec2:CreateSubnet
- 
							ec2:CreateTags
- 
							ec2:CreateVpc
- 
							ec2:CreateVpcEndpoint
- 
							ec2:CreateVolume
- 
							ec2:DescribeAccountAttributes
- 
							ec2:DescribeAddresses
- 
							ec2:DescribeAvailabilityZones
- 
							ec2:DescribeDhcpOptions
- 
							ec2:DescribeImages
- 
							ec2:DescribeInstanceAttribute
- 
							ec2:DescribeInstanceCreditSpecifications
- 
							ec2:DescribeInstances
- 
							ec2:DescribeInternetGateways
- 
							ec2:DescribeKeyPairs
- 
							ec2:DescribeNatGateways
- 
							ec2:DescribeNetworkAcls
- 
							ec2:DescribePrefixLists
- 
							ec2:DescribeRegions
- 
							ec2:DescribeRouteTables
- 
							ec2:DescribeSecurityGroups
- 
							ec2:DescribeSubnets
- 
							ec2:DescribeTags
- 
							ec2:DescribeVpcEndpoints
- 
							ec2:DescribeVpcs
- 
							ec2:DescribeVpcAttribute
- 
							ec2:DescribeVolumes
- 
							ec2:DescribeVpcClassicLink
- 
							ec2:DescribeVpcClassicLinkDnsSupport
- 
							ec2:ModifyInstanceAttribute
- 
							ec2:ModifySubnetAttribute
- 
							ec2:ModifyVpcAttribute
- 
							ec2:RevokeSecurityGroupEgress
- 
							ec2:RunInstances
- 
							ec2:TerminateInstances
- 
							ec2:RevokeSecurityGroupIngress
- 
							ec2:ReplaceRouteTableAssociation
- 
							ec2:DescribeNetworkInterfaces
- 
							ec2:ModifyNetworkInterfaceAttribute
Required Elasticloadbalancing permissions for installation
- 
							elasticloadbalancing:AddTags
- 
							elasticloadbalancing:ApplySecurityGroupsToLoadBalancer
- 
							elasticloadbalancing:AttachLoadBalancerToSubnets
- 
							elasticloadbalancing:CreateListener
- 
							elasticloadbalancing:CreateLoadBalancer
- 
							elasticloadbalancing:CreateLoadBalancerListeners
- 
							elasticloadbalancing:CreateTargetGroup
- 
							elasticloadbalancing:ConfigureHealthCheck
- 
							elasticloadbalancing:DeregisterInstancesFromLoadBalancer
- 
							elasticloadbalancing:DeregisterTargets
- 
							elasticloadbalancing:DescribeInstanceHealth
- 
							elasticloadbalancing:DescribeListeners
- 
							elasticloadbalancing:DescribeLoadBalancers
- 
							elasticloadbalancing:DescribeLoadBalancerAttributes
- 
							elasticloadbalancing:DescribeTags
- 
							elasticloadbalancing:DescribeTargetGroupAttributes
- 
							elasticloadbalancing:DescribeTargetHealth
- 
							elasticloadbalancing:ModifyLoadBalancerAttributes
- 
							elasticloadbalancing:ModifyTargetGroup
- 
							elasticloadbalancing:ModifyTargetGroupAttributes
- 
							elasticloadbalancing:RegisterTargets
- 
							elasticloadbalancing:RegisterInstancesWithLoadBalancer
- 
							elasticloadbalancing:SetLoadBalancerPoliciesOfListener
Required IAM permissions for installation
- 
							iam:AddRoleToInstanceProfile
- 
							iam:CreateInstanceProfile
- 
							iam:CreateRole
- 
							iam:DeleteInstanceProfile
- 
							iam:DeleteRole
- 
							iam:DeleteRolePolicy
- 
							iam:GetInstanceProfile
- 
							iam:GetRole
- 
							iam:GetRolePolicy
- 
							iam:GetUser
- 
							iam:ListInstanceProfilesForRole
- 
							iam:ListRoles
- 
							iam:ListUsers
- 
							iam:PassRole
- 
							iam:PutRolePolicy
- 
							iam:RemoveRoleFromInstanceProfile
- 
							iam:SimulatePrincipalPolicy
- 
							iam:TagRole
Required Route53 permissions for installation
- 
							route53:ChangeResourceRecordSets
- 
							route53:ChangeTagsForResource
- 
							route53:GetChange
- 
							route53:GetHostedZone
- 
							route53:CreateHostedZone
- 
							route53:ListHostedZones
- 
							route53:ListHostedZonesByName
- 
							route53:ListResourceRecordSets
- 
							route53:ListTagsForResource
- 
							route53:UpdateHostedZoneComment
Required S3 permissions for installation
- 
							s3:CreateBucket
- 
							s3:DeleteBucket
- 
							s3:GetAccelerateConfiguration
- 
							s3:GetBucketCors
- 
							s3:GetBucketLocation
- 
							s3:GetBucketLogging
- 
							s3:GetBucketObjectLockConfiguration
- 
							s3:GetBucketReplication
- 
							s3:GetBucketRequestPayment
- 
							s3:GetBucketTagging
- 
							s3:GetBucketVersioning
- 
							s3:GetBucketWebsite
- 
							s3:GetEncryptionConfiguration
- 
							s3:GetLifecycleConfiguration
- 
							s3:GetReplicationConfiguration
- 
							s3:ListBucket
- 
							s3:PutBucketAcl
- 
							s3:PutBucketTagging
- 
							s3:PutEncryptionConfiguration
S3 permissions that cluster Operators require
- 
							s3:PutObject
- 
							s3:PutObjectAcl
- 
							s3:PutObjectTagging
- 
							s3:GetObject
- 
							s3:GetObjectAcl
- 
							s3:GetObjectTagging
- 
							s3:GetObjectVersion
- 
							s3:DeleteObject
All additional permissions that are required to uninstall a cluster
- 
							autoscaling:DescribeAutoScalingGroups
- 
							ec2:DeleteDhcpOptions
- 
							ec2:DeleteInternetGateway
- 
							ec2:DeleteNatGateway
- 
							ec2:DeleteNetworkInterface
- 
							ec2:DeleteRoute
- 
							ec2:DeleteRouteTable
- 
							ec2:DeleteSnapshot
- 
							ec2:DeleteSecurityGroup
- 
							ec2:DeleteSubnet
- 
							ec2:DeleteVolume
- 
							ec2:DeleteVpc
- 
							ec2:DeleteVpcEndpoints
- 
							ec2:DeregisterImage
- 
							ec2:DetachInternetGateway
- 
							ec2:DisassociateRouteTable
- 
							ec2:ReleaseAddress
- 
							elasticloadbalancing:DescribeTargetGroups
- 
							elasticloadbalancing:DeleteTargetGroup
- 
							elasticloadbalancing:DeleteLoadBalancer
- 
							iam:ListInstanceProfiles
- 
							iam:ListRolePolicies
- 
							iam:ListUserPolicies
- 
							route53:DeleteHostedZone
- 
							tag:GetResources
1.1.4. Creating an IAM user
Each Amazon Web Services (AWS) account contains a root user account that is based on the email address you used to create the account. This is a highly-privileged account, and it is recommended to use it for only initial account and billing configuration, creating an initial set of users, and securing the account.
Before you install OpenShift Container Platform, create a secondary IAM administrative user. As you complete the Creating an IAM User in Your AWS Account procedure in the AWS documentation, set the following options:
Procedure
- 
							Specify the IAM user name and select Programmatic access.
- Attach the - AdministratorAccesspolicy to ensure that the account has sufficient permission to create the cluster. This policy provides the cluster with the ability to grant credentials to each OpenShift Container Platform component. The cluster grants the components only the credentials that they require.Note- While it is possible to create a policy that grants the all of the required AWS permissions and attach it to the user, this is not the preferred option. The cluster will not have the ability to grant additional credentials to individual components, so the same credentials are used by all components. 
- Optional: Add metadata to the user by attaching tags.
- 
							Confirm that the user name that you specified is granted the AdministratorAccesspolicy.
- Record the access key ID and secret access key values. You must use these values when you configure your local machine to run the installation program. Important- You cannot use a temporary session token that you generated while using a multi-factor authentication device to authenticate to AWS when you deploy a cluster. The cluster continues to use your current AWS credentials to create AWS resources for the entire life of the cluster, so you must use key-based, long-lived credentials. 
1.1.5. Supported AWS regions
You can deploy an OpenShift Container Platform cluster to the following regions:
- ap-northeast-1 (Tokyo)
- ap-northeast-2 (Seoul)
- ap-south-1 (Mumbai)
- ap-southeast-1 (Singapore)
- ap-southeast-2 (Sydney)
- ca-central-1 (Central)
- eu-central-1 (Frankfurt)
- eu-west-1 (Ireland)
- eu-west-2 (London)
- eu-west-3 (Paris)
- sa-east-1 (São Paulo)
- us-east-1 (N. Virginia)
- us-east-2 (Ohio)
- us-west-1 (N. California)
- us-west-2 (Oregon)
Next steps
- Install an OpenShift Container Platform cluster. You can install a customized cluster or quickly install a cluster with default options.
1.2. Installing a cluster quickly on AWS
In OpenShift Container Platform version 4.1, you can install a cluster on Amazon Web Services (AWS) that uses the default configuration options.
Prerequisites
- Review details about the OpenShift Container Platform installation and update processes.
- Configure an AWS account to host the cluster. Important- If you have an AWS profile stored on your computer, it must not use a temporary session token that you generated while using a multi-factor authentication device. The cluster continues to use your current AWS credentials to create AWS resources for the entire life of the cluster, so you must use key-based, long-lived credentials. To generate appropriate keys, see Managing Access Keys for IAM Users in the AWS documentation. You can supply the keys when you run the installation program. 
- If you use a firewall, you must configure it to access Red Hat Insights.
1.2.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
1.2.2. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
1.2.3. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
1.2.4. Deploy the cluster
You can install OpenShift Container Platform on a compatible cloud.
You can run the installation program only once, during initial installation.
Prerequisites
- Configure an account with the cloud platform that hosts your cluster.
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Run the installation program: - ./openshift-install create cluster --dir=<installation_directory> \ --log-level info- $ ./openshift-install create cluster --dir=<installation_directory> \- 1 - --log-level info- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. - Provide values at the prompts: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an Amazon Web Services (AWS) profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 Note- If the cloud provider account that you configured on your host does not have sufficient permissions to deploy the cluster, the installation process stops, and the missing permissions are displayed. - When the cluster deployment completes, directions for accessing your cluster, including a link to its web console and credentials for the - kubeadminuser, display in your terminal.Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. Important- You must not delete the installation program or the files that the installation program creates. Both are required to delete the cluster. 
- 
							Optional: Remove or disable the AdministratorAccesspolicy from the IAM account that you used to install the cluster.
1.2.5. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
1.2.6. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
1.3. Installing a cluster on AWS with customizations
				In OpenShift Container Platform version 4.1, you can install a customized cluster on infrastructure that the installation program provisions on Amazon Web Services (AWS). To customize the installation, you modify some parameters in the install-config.yaml file before you install the cluster.
			
Prerequisites
- Review details about the OpenShift Container Platform installation and update processes.
- Configure an AWS account to host the cluster. Important- If you have an AWS profile stored on your computer, it must not use a temporary session token that you generated while using a multi-factor authentication device. The cluster continues to use your current AWS credentials to create AWS resources for the entire life of the cluster, so you must use long-lived credentials. To generate appropriate keys, see Managing Access Keys for IAM Users in the AWS documentation. You can supply the keys when you run the installation program. 
- If you use a firewall, you must configure it to access Red Hat Insights.
1.3.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
1.3.2. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
1.3.3. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
1.3.4. Creating the installation configuration file
You can customize your installation of OpenShift Container Platform on a compatible cloud.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Create the - install-config.yamlfile.- Run the following command: - ./openshift-install create install-config --dir=<installation_directory> - $ ./openshift-install create install-config --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
 Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. 
- At the prompts, provide the configuration details for your cloud: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an Amazon Web Services (AWS) profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 
 
- 
							Modify the install-config.yamlfile. You can find more information about the available parameters in the Installation configuration parameters section and in the Go documentation.
- Back up the - install-config.yamlfile so that you can use it to install multiple clusters.Important- The - install-config.yamlfile is consumed during the installation process. If you want to reuse the file, you must back it up now.
1.3.4.1. Installation configuration parameters
						Before you deploy an OpenShift Container Platform cluster, you provide parameter values to describe your Amazon Web Services (AWS) account and optionally customize your cluster’s platform. When you create the install-config.yaml installation configuration file, you provide values for the required parameters through the command line. If you customize your cluster, you can modify the install-config.yaml file to provide more details about the platform.
					
You cannot modify these parameters after installation.
| Parameter | Description | Values | 
|---|---|---|
| 
										 | 
										The base domain of your cloud provider. This value is used to create routes to your OpenShift Container Platform cluster components. The full DNS name for your cluster is a combination of the  | 
										A fully-qualified domain or subdomain name, such as  | 
| 
										 | 
										The cloud provider to host the control plane machines. This parameter value must match the  | 
										 | 
| 
										 | 
										The cloud provider to host the worker machines. This parameter value must match the  | 
										 | 
| 
										 | The name of your cluster. | 
										A string that contains uppercase or lowercase letters, such as  | 
| 
										 | The region to deploy your cluster in. | 
										A valid AWS region, such as  | 
| 
										 | The pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site. You use this pull secret to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components. |  | 
| Parameter | Description | Values | 
|---|---|---|
| 
										 | The SSH key to use to access your cluster machines. Note 
											For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your  | 
										A valid, local public SSH key that you added to the  | 
| 
										 | 
										Whether to enable or disable simultaneous multithreading, or  Important If you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. | 
										 | 
| 
										 | The Input/Output Operations Per Second (IOPS) that is reserved for the root volume. | 
										Integer, for example  | 
| 
										 | The size in GiB of the root volume. | 
										Integer, for example  | 
| 
										 | The instance type of the root volume. | 
										Valid AWS EBS instance type, such as  | 
| 
										 | The EC2 instance type for the compute machines. | 
										Valid AWS instance type, such as  | 
| 
										 | The availability zones where the installation program creates machines for the compute MachinePool. | 
										A list of valid AWS availability zones, such as  | 
| 
										 | The AWS region that the installation program creates compute resources in. | 
										Valid AWS region, such as  | 
| 
										 | The number of compute machines, which are also known as worker machines, to provision. | 
										A positive integer greater than or equal to  | 
| 
										 | 
										Whether to enable or disable simultaneous multithreading, or  Important If you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. | 
										 | 
| 
										 | The EC2 instance type for the control plane machines. | 
										Valid AWS instance type, such as  | 
| 
										 | The availability zones where the installation program creates machines for the control plane MachinePool. | 
										A list of valid AWS availability zones, such as  | 
| 
										 | The AWS region that the installation program creates control plane resources in. | 
										Valid AWS region, such as  | 
| 
										 | The number of control plane machines to provision. | 
										A positive integer greater than or equal to  | 
| 
										 | A map of keys and values that the installation program adds as tags to all resources that it creates. | 
										Any valid YAML map, such as key value pairs in the  | 
1.3.4.2. Sample customized install-config.yaml file for AWS
						You can customize the install-config.yaml file to specify more details about your OpenShift Container Platform cluster’s platform or modify the values of the required parameters.
					
							This sample YAML file is provided for reference only. You must obtain your install-config.yaml file by using the installation program and modify it.
						
- 1 9 10 11
- Required. The installation program prompts you for this value.
- 2 6
- If you do not provide these parameters and values, the installation program provides the default value.
- 3 7
- ThecontrolPlanesection is a single mapping, but the compute section is a sequence of mappings. To meet the requirements of the different data structures, the first line of thecomputesection must begin with a hyphen,-, and the first line of thecontrolPlanesection must not. Although both sections currently define a single machine pool, it is possible that future versions of OpenShift Container Platform will support defining multiple compute pools during installation. Only one control plane pool is used.
- 4 5
- Whether to enable or disable simultaneous multithreading, orhyperthreading. By default, simultaneous multithreading is enabled to increase the performance of your machines' cores. You can disable it by setting the parameter value toDisabled. If you disable simultanous multithreading in some cluster machines, you must disable it in all cluster machines.ImportantIf you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. Use larger instance types, such as m4.2xlargeorm5.2xlarge, for your machines if you disable simultaneous multithreading.
- 8
- To configure faster storage for etcd, especially for larger clusters, set the storage type asio1and setiopsto2000.
- 12
- You can optionally provide thesshKeyvalue that you use to access the machines in your cluster.NoteFor production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agentprocess uses to the installation program.
1.3.5. Deploy the cluster
You can install OpenShift Container Platform on a compatible cloud.
You can run the installation program only once, during initial installation.
Prerequisites
- Configure an account with the cloud platform that hosts your cluster.
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Run the installation program: - ./openshift-install create cluster --dir=<installation_directory> \ --log-level info- $ ./openshift-install create cluster --dir=<installation_directory> \- 1 - --log-level info- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the location of your customized./install-config.yamlfile.
- 2
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
- To view different installation details, specifywarn,debug, orerrorinstead ofinfo.
 Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. - Provide values at the prompts: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an Amazon Web Services (AWS) profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 Note- If the cloud provider account that you configured on your host does not have sufficient permissions to deploy the cluster, the installation process stops, and the missing permissions are displayed. - When the cluster deployment completes, directions for accessing your cluster, including a link to its web console and credentials for the - kubeadminuser, display in your terminal.Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. Important- You must not delete the installation program or the files that the installation program creates. Both are required to delete the cluster. 
- 
							Optional: Remove or disable the AdministratorAccesspolicy from the IAM account that you used to install the cluster.
1.3.6. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
1.3.7. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
1.4. Installing a cluster on AWS with network customizations
In OpenShift Container Platform version 4.1, you can install a cluster on Amazon Web Services (AWS) with customized network configuration options. By customizing your network configuration, your cluster can coexist with existing IP address allocations in your environment and integrate with existing MTU and VXLAN configurations.
				You must set most of the network configuration parameters during installation, and you can modify only kubeProxy configuration parameters in a running cluster.
			
Prerequisites
- Review details about the OpenShift Container Platform installation and update processes.
- Configure an AWS account to host the cluster. Important- If you have an AWS profile stored on your computer, it must not use a temporary session token that you generated while using a multi-factor authentication device. The cluster continues to use your current AWS credentials to create AWS resources for the entire life of the cluster, so you must use key-based, long-lived credentials. To generate appropriate keys, see Managing Access Keys for IAM Users in the AWS documentation. You can supply the keys when you run the installation program. 
- If you use a firewall, you must configure it to access Red Hat Insights.
1.4.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
1.4.2. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
1.4.3. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
1.4.4. Creating the installation configuration file
You can customize your installation of OpenShift Container Platform on a compatible cloud.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Create the - install-config.yamlfile.- Run the following command: - ./openshift-install create install-config --dir=<installation_directory> - $ ./openshift-install create install-config --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
 Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. 
- At the prompts, provide the configuration details for your cloud: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an Amazon Web Services (AWS) profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 
 
- 
							Modify the install-config.yamlfile. You can find more information about the available parameters in the Installation configuration parameters section and in the Go documentation.
- Back up the - install-config.yamlfile so that you can use it to install multiple clusters.Important- The - install-config.yamlfile is consumed during the installation process. If you want to reuse the file, you must back it up now.
1.4.4.1. Installation configuration parameters
						Before you deploy an OpenShift Container Platform cluster, you provide parameter values to describe your Amazon Web Services (AWS) account and optionally customize your cluster’s platform. When you create the install-config.yaml installation configuration file, you provide values for the required parameters through the command line. If you customize your cluster, you can modify the install-config.yaml file to provide more details about the platform.
					
You cannot modify these parameters after installation.
| Parameter | Description | Values | 
|---|---|---|
| 
										 | 
										The base domain of your cloud provider. This value is used to create routes to your OpenShift Container Platform cluster components. The full DNS name for your cluster is a combination of the  | 
										A fully-qualified domain or subdomain name, such as  | 
| 
										 | 
										The cloud provider to host the control plane machines. This parameter value must match the  | 
										 | 
| 
										 | 
										The cloud provider to host the worker machines. This parameter value must match the  | 
										 | 
| 
										 | The name of your cluster. | 
										A string that contains uppercase or lowercase letters, such as  | 
| 
										 | The region to deploy your cluster in. | 
										A valid AWS region, such as  | 
| 
										 | The pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site. You use this pull secret to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components. |  | 
| Parameter | Description | Values | 
|---|---|---|
| 
										 | The SSH key to use to access your cluster machines. Note 
											For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your  | 
										A valid, local public SSH key that you added to the  | 
| 
										 | 
										Whether to enable or disable simultaneous multithreading, or  Important If you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. | 
										 | 
| 
										 | The Input/Output Operations Per Second (IOPS) that is reserved for the root volume. | 
										Integer, for example  | 
| 
										 | The size in GiB of the root volume. | 
										Integer, for example  | 
| 
										 | The instance type of the root volume. | 
										Valid AWS EBS instance type, such as  | 
| 
										 | The EC2 instance type for the compute machines. | 
										Valid AWS instance type, such as  | 
| 
										 | The availability zones where the installation program creates machines for the compute MachinePool. | 
										A list of valid AWS availability zones, such as  | 
| 
										 | The AWS region that the installation program creates compute resources in. | 
										Valid AWS region, such as  | 
| 
										 | The number of compute machines, which are also known as worker machines, to provision. | 
										A positive integer greater than or equal to  | 
| 
										 | 
										Whether to enable or disable simultaneous multithreading, or  Important If you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. | 
										 | 
| 
										 | The EC2 instance type for the control plane machines. | 
										Valid AWS instance type, such as  | 
| 
										 | The availability zones where the installation program creates machines for the control plane MachinePool. | 
										A list of valid AWS availability zones, such as  | 
| 
										 | The AWS region that the installation program creates control plane resources in. | 
										Valid AWS region, such as  | 
| 
										 | The number of control plane machines to provision. | 
										A positive integer greater than or equal to  | 
| 
										 | A map of keys and values that the installation program adds as tags to all resources that it creates. | 
										Any valid YAML map, such as key value pairs in the  | 
1.4.4.2. Network configuration parameters
						You can modify your cluster network configuration parameters in the install-config.yaml configuration file. The following table describes the parameters.
					
You cannot modify these parameters after installation.
| Parameter | Description | Values | 
|---|---|---|
| 
										 | 
										The network plug-in to deploy.  | 
										 | 
| 
										 | 
										A block of IP addresses from which Pod IP addresses are allocated. The  | 
										An IP address allocation in CIDR format. The default value is  | 
| 
										 | 
										The subnet prefix length to assign to each individual node. For example, if  | 
										A subnet prefix. The default value is  | 
| 
										 | 
										A block of IP addresses for services.  | 
										An IP address allocation in CIDR format. The default value is  | 
| 
										 | A block of IP addresses used by the OpenShift Container Platform installation program while installing the cluster. The address block must not overlap with any other network block. | 
										An IP address allocation in CIDR format. The default value is  | 
1.4.4.3. Sample customized install-config.yaml file for AWS
						You can customize the install-config.yaml file to specify more details about your OpenShift Container Platform cluster’s platform or modify the values of the required parameters.
					
							This sample YAML file is provided for reference only. You must obtain your install-config.yaml file by using the installation program and modify it.
						
- 1 9 11 12
- Required. The installation program prompts you for this value.
- 2 6 10
- If you do not provide these parameters and values, the installation program provides the default value.
- 3 7
- ThecontrolPlanesection is a single mapping, but the compute section is a sequence of mappings. To meet the requirements of the different data structures, the first line of thecomputesection must begin with a hyphen,-, and the first line of thecontrolPlanesection must not. Although both sections currently define a single machine pool, it is possible that future versions of OpenShift Container Platform will support defining multiple compute pools during installation. Only one control plane pool is used.
- 4 5
- Whether to enable or disable simultaneous multithreading, orhyperthreading. By default, simultaneous multithreading is enabled to increase the performance of your machines' cores. You can disable it by setting the parameter value toDisabled. If you disable simultanous multithreading in some cluster machines, you must disable it in all cluster machines.ImportantIf you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. Use larger instance types, such as m4.2xlargeorm5.2xlarge, for your machines if you disable simultaneous multithreading.
- 8
- To configure faster storage for etcd, especially for larger clusters, set the storage type asio1and setiopsto2000.
- 13
- You can optionally provide thesshKeyvalue that you use to access the machines in your cluster.NoteFor production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agentprocess uses to the installation program.
1.4.5. Modifying advanced network configuration parameters
					You can modify the advanced network configuration parameters only before you install the cluster. Advanced configuration customization lets you integrate your cluster into your existing network environment by specifying an MTU or VXLAN port, by allowing customization of kube-proxy settings, and by specifying a different mode for the openshiftSDNConfig parameter.
				
Modifying the OpenShift Container Platform manifest files directly is not supported.
Prerequisites
- 
							Generate the install-config.yamlfile and complete any modifications to it.
Procedure
- Use the following command to create manifests: - ./openshift-install create manifests --dir=<installation_directory> - $ ./openshift-install create manifests --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the name of the directory that contains theinstall-config.yamlfile for your cluster.
 
- Create a file that is named - cluster-network-03-config.ymlin the- <installation_directory>/manifests/directory:- touch <installation_directory>/manifests/cluster-network-03-config.yml - $ touch <installation_directory>/manifests/cluster-network-03-config.yml- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name that contains themanifests/directory for your cluster.
 - After creating the file, three network configuration files are in the - manifests/directory, as shown:- ls <installation_directory>/manifests/cluster-network-* - $ ls <installation_directory>/manifests/cluster-network-* cluster-network-01-crd.yml cluster-network-02-config.yml cluster-network-03-config.yml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Open the - cluster-network-03-config.ymlfile in an editor and enter a CR that describes the Operator configuration you want:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The parameters for thespecfield are only an example. Specify your configuration for the Network Operator in the CR.
 - The Network Operator provides default values for the parameters in the CR, so you must specify only the parameters that you want to change in the - Network.operator.openshift.ioCR.
- 
							Save the cluster-network-03-config.ymlfile and quit the text editor.
- 
							Optional: Back up the manifests/cluster-network-03-config.ymlfile. The installation program deletes themanifests/directory when creating the cluster.
1.4.6. Cluster Network Operator custom resource (CR)
					The cluster network configuration in the Network.operator.openshift.io custom resource (CR) stores the configuration settings for the Cluster Network Operator (CNO).
				
The following CR displays the default configuration for the CNO and explains both the parameters you can configure and valid parameter values:
Cluster Network Operator CR
- 1 2 3
- Specified in theinstall-config.yamlfile.
- 4
- Specify only if you want to override part of the OpenShift Container Platform SDN configuration.
- 5
- Configures the isolation mode forOpenShiftSDN. The allowed values areMultitenant,Subnet, orNetworkPolicy. The default value isNetworkPolicy.
- 6
- MTU for the VXLAN overlay network. This value is normally configured automatically, but if the nodes in your cluster do not all use the same MTU, then you must set this explicitly to 50 less than the smallest node MTU value.
- 7
- The port to use for all VXLAN packets. The default value is4789. If you are running in a virtualized environment with existing nodes that are part of another VXLAN network then you might be required to change this. For example, when running an OpenShift SDN overlay on top of VMware NSX-T, you must select an alternate port for VXLAN, since both SDNs use the same default VXLAN port number.On Amazon Web Services (AWS), you can select an alternate port for the VXLAN between port 9000and port9999.
- 8
- The parameters for this object specify thekube-proxyconfiguration. If you do not specify the parameter values, the Network Operator applies the displayed default parameter values.
- 9
- The refresh period foriptablesrules. The default value is30s. Valid suffixes includes,m, andhand are described in the Go time package documentation.
- 10
- The minimum duration before refreshingiptablesrules. This parameter ensures that the refresh does not happen too frequently. Valid suffixes includes,m, andhand are described in the Go time package
1.4.7. Deploy the cluster
You can install OpenShift Container Platform on a compatible cloud.
You can run the installation program only once, during initial installation.
Prerequisites
- Configure an account with the cloud platform that hosts your cluster.
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Run the installation program: - ./openshift-install create cluster --dir=<installation_directory> \ --log-level info- $ ./openshift-install create cluster --dir=<installation_directory> \- 1 - --log-level info- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the location of your customized./install-config.yamlfile.
- 2
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
- To view different installation details, specifywarn,debug, orerrorinstead ofinfo.
 Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. - Provide values at the prompts: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an Amazon Web Services (AWS) profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 Note- If the cloud provider account that you configured on your host does not have sufficient permissions to deploy the cluster, the installation process stops, and the missing permissions are displayed. - When the cluster deployment completes, directions for accessing your cluster, including a link to its web console and credentials for the - kubeadminuser, display in your terminal.Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. Important- You must not delete the installation program or the files that the installation program creates. Both are required to delete the cluster. 
- 
							Optional: Remove or disable the AdministratorAccesspolicy from the IAM account that you used to install the cluster.
1.4.8. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
1.4.9. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
1.5. Uninstalling a cluster on AWS
You can remove a cluster that you deployed to Amazon Web Services (AWS).
1.5.1. Removing a cluster from AWS
You can remove a cluster that you installed on Amazon Web Services (AWS).
Prerequisites
- Have a copy of the installation program that you used to deploy the cluster.
- Have the files that the installation program generated when you created your cluster.
Procedure
- From the computer that you used to install the cluster, run the following command: - ./openshift-install destroy cluster \ --dir=<installation_directory> --log-level=info - $ ./openshift-install destroy cluster \ --dir=<installation_directory> --log-level=info- 1 - 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Note- You must specify the directory that contains the cluster definition files for your cluster. The installation program requires the - metadata.jsonfile in this directory to delete the cluster.
- 
							Optional: Delete the <installation_directory>directory and the OpenShift Container Platform installation program.
Chapter 2. Installing on user-provisioned AWS
2.1. Installing a cluster on AWS using CloudFormation templates
In OpenShift Container Platform version 4.1, you can install a cluster on Amazon Web Services (AWS) using infrastructure that you provide.
One way to create this infrastructure is to use the provided CloudFormation templates. You can modify the templates to customize your infrastructure or use the information that they contain to create AWS objects according to your company’s policies.
Prerequisites
- Review details about the OpenShift Container Platform installation and update processes.
- Configure an AWS account to host the cluster. Important- If you have an AWS profile stored on your computer, it must not use a temporary session token that you generated while using a multi-factor authentication device. The cluster continues to use your current AWS credentials to create AWS resources for the entire life of the cluster, so you must use key-based, long-lived credentials. To generate appropriate keys, see Managing Access Keys for IAM Users in the AWS documentation. You can supply the keys when you run the installation program. 
- Download the AWS CLI and install it on your computer. See Install the AWS CLI Using the Bundled Installer (Linux, macOS, or Unix) in the AWS documentation.
- If you use a firewall, you must configure it to access Red Hat Insights.
2.1.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
2.1.2. Required AWS infrastructure components
To install OpenShift Container Platform on user-provisioned infrastructure in Amazon Web Services (AWS), you must manually create both the machines and their supporting infrastructure.
For more information about the integration testing for different platforms, see the OpenShift Container Platform 4.x Tested Integrations page.
You can use the provided CloudFormation templates to create this infrastructure, you can manually create the components, or you can reuse existing infrastructure that meets the cluster requirements. Review the CloudFormation templates for more details about how the components interrelate.
2.1.2.1. Cluster machines
						You need AWS::EC2::Instance objects for the following machines:
					
- A bootstrap machine. This machine is required during installation, but you can remove it after your cluster deploys.
- At least three control plane machines. The control plane machines are not governed by a MachineSet.
- Compute machines. You must create at least two compute machines, which are also known as worker machines, during installation. These machines are not governed by a MachineSet.
You can use the following instance types for the cluster machines:
							If m4 instance types are not available in your region, such as with eu-west-3, use m5 types instead.
						
| Instance type | Bootstrap | Control plane | Compute | 
|---|---|---|---|
| 
										 | x | ||
| 
										 | x | ||
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | ||
| 
										 | x | ||
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | ||
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | |
| 
										 | x | x | 
You might be able to use other instance types that meet the specifications of these instance types.
2.1.2.2. Certificate signing requests management
						Because your cluster has limited access to automatic machine management when you use infrastructure that you provision, you must provide a mechanism for approving cluster certificate signing requests (CSRs) after installation. The kube-controller-manager only approves the kubelet client CSRs. The machine-approver cannot guarantee the validity of a serving certificate that is requested by using kubelet credentials because it cannot confirm that the correct machine issued the request. You must determine and implement a method of verifying the validity of the kubelet serving certificate requests and approving them.
					
2.1.2.3. Other infrastructure components
- A VPC
- DNS entries
- Load balancers (classic or network) and listeners
- A Route53 zone
- Security groups
- IAM roles
- S3 buckets
Required VPC components
You must provide a suitable VPC and subnets that allow communication to your machines.
| Component | AWS type | Description | |
|---|---|---|---|
| VPC | 
 | You must provide a public VPC for the cluster to use. The VPC requires an endpoint that references the route tables for each subnet. | |
| Public subnets | 
 | Your VPC must have public subnets for between 1 and 3 availability zones and associate them with appropriate Ingress rules. | |
| Internet gateway | 
 | You must have a public internet gateway, with public routes, attached to the VPC. Each public subnet must also be attached to the route and have a NAT gateway and EIP address. | |
| Network access control | 
 | You must allow the VPC to access the following ports: | |
| Port | Reason | ||
| 
										 | Inbound HTTP traffic | ||
| 
										 | Inbound HTTPS traffic | ||
| 
										 | Inbound SSH traffic | ||
| 
										 | Inbound ephemeral traffic | ||
| 
										 | Outbound ephemeral traffic | ||
| Private subnets | 
 | Your VPC can have a private subnets. The provided CloudFormation templates can create private subnets for between 1 and 3 availability zones. If you use private subnets, you must provide appropriate routes and tables for them. | |
Required DNS and load balancing components
							Your DNS and load balancer configuration needs to use a public hosted zone and can use a private hosted zone similar to the one that the installation program uses if it provisions the cluster’s infrastructure. You must create a DNS entry that resolves to your load balancer. An entry for api.<cluster_name>.<domain> must point to the external load balancer, and an entry for api-int.<cluster_name>.<domain> must point to the internal load balancer.
						
The cluster also requires load balancers and listeners for port 6443, which are required for the Kubernetes API and its extensions, and port 22623, which are required for the Ignition config files for new machines. The targets will be the master nodes. Port 6443 must be accessible to both clients external to the cluster and nodes within the cluster. Port 22623 must be accessible to nodes within the cluster.
| Component | AWS type | Description | 
|---|---|---|
| DNS | 
										 | The hosted zone for your internal DNS. | 
| etcd record sets | 
										 | The registration records for etcd for your control plane machines. | 
| Public load balancer | 
										 | The load balancer for your public subnets. | 
| External API server record | 
										 | Alias records for the external API server. | 
| External listener | 
										 | A listener on port 6443 for the external load balancer. | 
| External target group | 
										 | The target group for the external load balancer. | 
| Private load balancer | 
										 | The load balancer for your private subnets. | 
| Internal API server record | 
										 | Alias records for the internal API server. | 
| Internal listener | 
										 | A listener on port 22623 for the internal load balancer. | 
| Internal target group | 
										 | The target group for the Internal load balancer. | 
| Internal listener | 
										 | A listener on port 6443 for the internal load balancer. | 
| Internal target group | 
										 | The target group for the Internal load balancer. | 
Security groups
The control plane and worker machines require access to the following ports:
| Group | Type | IP Protocol | Port range | 
|---|---|---|---|
| MasterSecurityGroup | 
										 | 
										 | 
										 | 
| 
										 | 
										 | ||
| 
										 | 
										 | ||
| 
										 | 
										 | ||
| WorkerSecurityGroup | 
										 | 
										 | 
										 | 
| 
										 | 
										 | ||
| BootstrapSecurityGroup | 
										 | 
										 | 
										 | 
| 
										 | 
										 | 
Control plane Ingress
							The control plane machines require the following Ingress groups. Each Ingress group is a AWS::EC2::SecurityGroupIngress resource.
						
| Ingress group | Description | IP protocol | Port range | 
|---|---|---|---|
| 
										 | etcd | 
										 | 
										 | 
| 
										 | Vxlan packets | 
										 | 
										 | 
| 
										 | Vxlan packets | 
										 | 
										 | 
| 
										 | Internal cluster communication and Kubernetes proxy metrics | 
										 | 
										 | 
| 
										 | Internal cluster communication | 
										 | 
										 | 
| 
										 | Kubernetes kubelet, scheduler and controller manager | 
										 | 
										 | 
| 
										 | Kubernetes kubelet, scheduler and controller manager | 
										 | 
										 | 
| 
										 | Kubernetes Ingress services | 
										 | 
										 | 
| 
										 | Kubernetes Ingress services | 
										 | 
										 | 
Worker Ingress
							The worker machines require the following Ingress groups. Each Ingress group is a AWS::EC2::SecurityGroupIngress resource.
						
| Ingress group | Description | IP protocol | Port range | 
|---|---|---|---|
| 
										 | Vxlan packets | 
										 | 
										 | 
| 
										 | Vxlan packets | 
										 | 
										 | 
| 
										 | Internal cluster communication | 
										 | 
										 | 
| 
										 | Internal cluster communication | 
										 | 
										 | 
| 
										 | Kubernetes kubelet, scheduler and controller manager | 
										 | 
										 | 
| 
										 | Kubernetes kubelet, scheduler and controller manager | 
										 | 
										 | 
| 
										 | Kubernetes Ingress services | 
										 | 
										 | 
| 
										 | Kubernetes Ingress services | 
										 | 
										 | 
Roles and instance profiles
							You must grant the machines permissions in AWS. The provided CloudFormation templates grant the machines permission the following AWS::IAM::Role objects and provide a AWS::IAM::InstanceProfile for each set of roles. If you do not use the templates, you can grant the machines the following broad permissions or the following individual permissions.
						
| Role | Effect | Action | Resource | 
|---|---|---|---|
| Master | 
										 | 
										 | 
										 | 
| 
										 | 
										 | 
										 | |
| 
										 | 
										 | 
										 | |
| 
										 | 
										 | 
										 | |
| Worker | 
										 | 
										 | 
										 | 
| Bootstrap | 
										 | 
										 | 
										 | 
| 
										 | 
										 | 
										 | |
| 
										 | 
										 | 
										 | 
2.1.2.4. Required AWS permissions
						When you attach the AdministratorAccess policy to the IAM user that you create, you grant that user all of the required permissions. To deploy an OpenShift Container Platform cluster, the IAM user requires the following permissions:
					
Required EC2 permissions for installation
- 
								ec2:AllocateAddress
- 
								ec2:AssociateAddress
- 
								ec2:AssociateDhcpOptions
- 
								ec2:AssociateRouteTable
- 
								ec2:AttachInternetGateway
- 
								ec2:AuthorizeSecurityGroupEgress
- 
								ec2:AuthorizeSecurityGroupIngress
- 
								ec2:CopyImage
- 
								ec2:CreateDhcpOptions
- 
								ec2:CreateInternetGateway
- 
								ec2:CreateNatGateway
- 
								ec2:CreateRoute
- 
								ec2:CreateRouteTable
- 
								ec2:CreateSecurityGroup
- 
								ec2:CreateSubnet
- 
								ec2:CreateTags
- 
								ec2:CreateVpc
- 
								ec2:CreateVpcEndpoint
- 
								ec2:CreateVolume
- 
								ec2:DescribeAccountAttributes
- 
								ec2:DescribeAddresses
- 
								ec2:DescribeAvailabilityZones
- 
								ec2:DescribeDhcpOptions
- 
								ec2:DescribeImages
- 
								ec2:DescribeInstanceAttribute
- 
								ec2:DescribeInstanceCreditSpecifications
- 
								ec2:DescribeInstances
- 
								ec2:DescribeInternetGateways
- 
								ec2:DescribeKeyPairs
- 
								ec2:DescribeNatGateways
- 
								ec2:DescribeNetworkAcls
- 
								ec2:DescribePrefixLists
- 
								ec2:DescribeRegions
- 
								ec2:DescribeRouteTables
- 
								ec2:DescribeSecurityGroups
- 
								ec2:DescribeSubnets
- 
								ec2:DescribeTags
- 
								ec2:DescribeVpcEndpoints
- 
								ec2:DescribeVpcs
- 
								ec2:DescribeVpcAttribute
- 
								ec2:DescribeVolumes
- 
								ec2:DescribeVpcClassicLink
- 
								ec2:DescribeVpcClassicLinkDnsSupport
- 
								ec2:ModifyInstanceAttribute
- 
								ec2:ModifySubnetAttribute
- 
								ec2:ModifyVpcAttribute
- 
								ec2:RevokeSecurityGroupEgress
- 
								ec2:RunInstances
- 
								ec2:TerminateInstances
- 
								ec2:RevokeSecurityGroupIngress
- 
								ec2:ReplaceRouteTableAssociation
- 
								ec2:DescribeNetworkInterfaces
- 
								ec2:ModifyNetworkInterfaceAttribute
Required Elasticloadbalancing permissions for installation
- 
								elasticloadbalancing:AddTags
- 
								elasticloadbalancing:ApplySecurityGroupsToLoadBalancer
- 
								elasticloadbalancing:AttachLoadBalancerToSubnets
- 
								elasticloadbalancing:CreateListener
- 
								elasticloadbalancing:CreateLoadBalancer
- 
								elasticloadbalancing:CreateLoadBalancerListeners
- 
								elasticloadbalancing:CreateTargetGroup
- 
								elasticloadbalancing:ConfigureHealthCheck
- 
								elasticloadbalancing:DeregisterInstancesFromLoadBalancer
- 
								elasticloadbalancing:DeregisterTargets
- 
								elasticloadbalancing:DescribeInstanceHealth
- 
								elasticloadbalancing:DescribeListeners
- 
								elasticloadbalancing:DescribeLoadBalancers
- 
								elasticloadbalancing:DescribeLoadBalancerAttributes
- 
								elasticloadbalancing:DescribeTags
- 
								elasticloadbalancing:DescribeTargetGroupAttributes
- 
								elasticloadbalancing:DescribeTargetHealth
- 
								elasticloadbalancing:ModifyLoadBalancerAttributes
- 
								elasticloadbalancing:ModifyTargetGroup
- 
								elasticloadbalancing:ModifyTargetGroupAttributes
- 
								elasticloadbalancing:RegisterTargets
- 
								elasticloadbalancing:RegisterInstancesWithLoadBalancer
- 
								elasticloadbalancing:SetLoadBalancerPoliciesOfListener
Required IAM permissions for installation
- 
								iam:AddRoleToInstanceProfile
- 
								iam:CreateInstanceProfile
- 
								iam:CreateRole
- 
								iam:DeleteInstanceProfile
- 
								iam:DeleteRole
- 
								iam:DeleteRolePolicy
- 
								iam:GetInstanceProfile
- 
								iam:GetRole
- 
								iam:GetRolePolicy
- 
								iam:GetUser
- 
								iam:ListInstanceProfilesForRole
- 
								iam:ListRoles
- 
								iam:ListUsers
- 
								iam:PassRole
- 
								iam:PutRolePolicy
- 
								iam:RemoveRoleFromInstanceProfile
- 
								iam:SimulatePrincipalPolicy
- 
								iam:TagRole
Required Route53 permissions for installation
- 
								route53:ChangeResourceRecordSets
- 
								route53:ChangeTagsForResource
- 
								route53:GetChange
- 
								route53:GetHostedZone
- 
								route53:CreateHostedZone
- 
								route53:ListHostedZones
- 
								route53:ListHostedZonesByName
- 
								route53:ListResourceRecordSets
- 
								route53:ListTagsForResource
- 
								route53:UpdateHostedZoneComment
Required S3 permissions for installation
- 
								s3:CreateBucket
- 
								s3:DeleteBucket
- 
								s3:GetAccelerateConfiguration
- 
								s3:GetBucketCors
- 
								s3:GetBucketLocation
- 
								s3:GetBucketLogging
- 
								s3:GetBucketObjectLockConfiguration
- 
								s3:GetBucketReplication
- 
								s3:GetBucketRequestPayment
- 
								s3:GetBucketTagging
- 
								s3:GetBucketVersioning
- 
								s3:GetBucketWebsite
- 
								s3:GetEncryptionConfiguration
- 
								s3:GetLifecycleConfiguration
- 
								s3:GetReplicationConfiguration
- 
								s3:ListBucket
- 
								s3:PutBucketAcl
- 
								s3:PutBucketTagging
- 
								s3:PutEncryptionConfiguration
S3 permissions that cluster Operators require
- 
								s3:PutObject
- 
								s3:PutObjectAcl
- 
								s3:PutObjectTagging
- 
								s3:GetObject
- 
								s3:GetObjectAcl
- 
								s3:GetObjectTagging
- 
								s3:GetObjectVersion
- 
								s3:DeleteObject
All additional permissions that are required to uninstall a cluster
- 
								autoscaling:DescribeAutoScalingGroups
- 
								ec2:DeleteDhcpOptions
- 
								ec2:DeleteInternetGateway
- 
								ec2:DeleteNatGateway
- 
								ec2:DeleteNetworkInterface
- 
								ec2:DeleteRoute
- 
								ec2:DeleteRouteTable
- 
								ec2:DeleteSnapshot
- 
								ec2:DeleteSecurityGroup
- 
								ec2:DeleteSubnet
- 
								ec2:DeleteVolume
- 
								ec2:DeleteVpc
- 
								ec2:DeleteVpcEndpoints
- 
								ec2:DeregisterImage
- 
								ec2:DetachInternetGateway
- 
								ec2:DisassociateRouteTable
- 
								ec2:ReleaseAddress
- 
								elasticloadbalancing:DescribeTargetGroups
- 
								elasticloadbalancing:DeleteTargetGroup
- 
								elasticloadbalancing:DeleteLoadBalancer
- 
								iam:ListInstanceProfiles
- 
								iam:ListRolePolicies
- 
								iam:ListUserPolicies
- 
								route53:DeleteHostedZone
- 
								tag:GetResources
2.1.3. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
2.1.4. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
2.1.5. Creating the installation files for AWS
					To install OpenShift Container Platform on Amazon Web Services (AWS) using user-provisioned infrastructure, you must generate the files that the installation program needs to deploy your cluster and modify them so that the cluster creates only the machines that it will use. You generate and customize the install_config.yaml file, Kubernetes manifests, and Ignition config files.
				
The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must complete your cluster installation and keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Obtain the - install-config.yamlfile.- Run the following command: - ./openshift-install create install-config --dir=<installation_directory> - $ ./openshift-install create install-config --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
 Important- Specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. 
- At the prompts, provide the configuration details for your cloud: - Optional: Select an SSH key to use to access your cluster machines. Note- For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your - ssh-agentprocess uses to the installation program.
- Select AWS as the platform to target.
- If you do not have an AWS profile stored on your computer, enter the AWS access key ID and secret access key for the user that you configured to run the installation program.
- Select the AWS region to deploy the cluster to.
- Select the base domain for the Route53 service that you configured for your cluster.
- Enter a descriptive name for your cluster.
- Paste the pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site.
 
 
- Edit the - install-config.yamlfile to set the number of compute, or worker, replicas to- 0, as shown in the following- computestanza:- compute: - hyperthreading: Enabled name: worker platform: {} replicas: 0- compute: - hyperthreading: Enabled name: worker platform: {} replicas: 0- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Back up the - install-config.yamlfile.Important- The - install-config.yamlfile is consumed during the next step. If you want to reuse the file, back it up now.
- Remove the Kubernetes manifest files for the control plane machines. By removing these files, you prevent the cluster from automatically generating control plane machines. - Generate the Kubernetes manifests for the cluster: - ./openshift-install create manifests --dir=<installation_directory> - $ ./openshift-install create manifests --dir=<installation_directory>- 1 - WARNING There are no compute nodes specified. The cluster will not fully initialize without compute nodes. INFO Consuming "Install Config" from target directory- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the same installation directory.
 - Because you create your own compute machines later in the installation process, you can safely ignore this warning. 
- Remove the files that define the control plane machines: - rm -f openshift/99_openshift-cluster-api_master-machines-*.yaml - $ rm -f openshift/99_openshift-cluster-api_master-machines-*.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Remove the Kubernetes manifest files that define the worker machines: - rm -f openshift/99_openshift-cluster-api_worker-machineset-* - $ rm -f openshift/99_openshift-cluster-api_worker-machineset-*- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Because you create and manage the worker machines yourself, you do not need to initialize these machines. 
- Obtain the Ignition config files: - ./openshift-install create ignition-configs --dir=<installation_directory> - $ ./openshift-install create ignition-configs --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the same installation directory.
 - The following files are generated in the directory: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
2.1.6. Extracting the infrastructure name
The Ignition configs contain a unique cluster identifier that you can use to uniquely identify your cluster in Amazon Web Services (AWS) tags. The provided CloudFormation templates contain references to this tag, so you must extract it.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
- Generate the Ignition config files for your cluster.
- 
							Install the jqpackage.
Procedure
- To extract the infrastructure name from the Ignition config file metadata, run the following command: - jq -r .infraID /<installation_directory>/metadata.json - $ jq -r .infraID /<installation_directory>/metadata.json- 1 - openshift-vw9j6- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You need the output of this command to configure the provided CloudFormation templates and can use it in other AWS tags. 
2.1.7. Creating a VPC in AWS
You must create a VPC in Amazon Web Services (AWS) for your OpenShift Container Platform cluster to use. You can customize the VPC to meet your requirements, including VPN and route tables. The easiest way to create the VPC is to modify the provided CloudFormation template.
If you do not use the provided CloudFormation template to create your AWS infrastructure, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
Procedure
- Create a JSON file that contains the parameter values that the template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Copy the template from the CloudFormation template for the VPC section of this topic and save it as a YAML file on your computer. This template describes the VPC that your cluster requires.
- Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml- 2 - --parameters file://<parameters>.json- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-vpc. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the - StackStatusdisplays- CREATE_COMPLETE, the output displays values for the following parameters. You must provide these parameter values to the other CloudFormation templates that you run to create your cluster:- VpcId- The ID of your VPC. - PublicSubnetIds- The IDs of the new public subnets. - PrivateSubnetIds- The IDs of the new private subnets. 
2.1.7.1. CloudFormation template for the VPC
You can use the following CloudFormation template to deploy the VPC that you need for your OpenShift Container Platform cluster.
2.1.8. Creating networking and load balancing components in AWS
You must configure networking and load balancing (classic or network) in Amazon Web Services (AWS) for your OpenShift Container Platform cluster to use. The easiest way to create these components is to modify the provided CloudFormation template, which also creates a hosted zone and subnet tags.
You can run the template multiple times within a single VPC.
If you do not use the provided CloudFormation template to create your AWS infrastructure, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
Procedure
- Obtain the Hosted Zone ID for the Route53 zone that you specified in the - install-config.yamlfile for your cluster. You can obtain this ID from the AWS console or by running the following command:Important- You must enter the command on a single line. - aws route53 list-hosted-zones-by-name | - $ aws route53 list-hosted-zones-by-name | jq --arg name "<route53_domain>." \- 1 - -r '.HostedZones | .[] | select(.Name=="\($name)") | .Id'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For the<route53_domain>, specify the Route53 base domain that you used when you generated theinstall-config.yamlfile for the cluster.
 
- Create a JSON file that contains the parameter values that the template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- A short, representative cluster name to use for host names, etc.
- 2
- Specify the cluster name that you used when you generated theinstall-config.yamlfile for the cluster.
- 3
- The name for your cluster infrastructure that is encoded in your Ignition config files for the cluster.
- 4
- Specify the infrastructure name that you extracted from the Ignition config file metadata, which has the format<cluster-name>-<random-string>.
- 5
- The Route53 public zone ID to register the targets with.
- 6
- Specify the Route53 public zone ID, which as a format similar toZ21IXYZABCZ2A4. You can obtain this value from the AWS console.
- 7
- The Route53 zone to register the targets with.
- 8
- Specify the Route53 base domain that you used when you generated theinstall-config.yamlfile for the cluster. Do not include the trailing period (.) that is displayed in the AWS console.
- 9
- The public subnets that you created for your VPC.
- 10
- Specify thePublicSubnetIdsvalue from the output of the CloudFormation template for the VPC.
- 11
- The private subnets that you created for your VPC.
- 12
- Specify thePrivateSubnetIdsvalue from the output of the CloudFormation template for the VPC.
- 13
- The VPC that you created for the cluster.
- 14
- Specify theVpcIdvalue from the output of the CloudFormation template for the VPC.
 
- Copy the template from the CloudFormation template for the network and load balancers section of this topic and save it as a YAML file on your computer. This template describes the networking and load balancing objects that your cluster requires.
- Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml- 2 - --parameters file://<parameters>.json- 3 - --capabilities CAPABILITY_NAMED_IAM- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-dns. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the - StackStatusdisplays- CREATE_COMPLETE, the output displays values for the following parameters. You must provide these parameter values to the other CloudFormation templates that you run to create your cluster:- PrivateHostedZoneId- Hosted zone ID for the private DNS. - ExternalApiLoadBalancerName- Full name of the external API load balancer. - InternalApiLoadBalancerName- Full name of the internal API load balancer. - ApiServerDnsName- Full host name of the API server. - RegisterNlbIpTargetsLambda- Lambda ARN useful to help register/deregister IP targets for these load balancers. - ExternalApiTargetGroupArn- ARN of external API target group. - InternalApiTargetGroupArn- ARN of internal API target group. - InternalServiceTargetGroupArn- ARN of internal service target group. 
2.1.8.1. CloudFormation template for the network and load balancers
You can use the following CloudFormation template to deploy the networking objects and load balancers that you need for your OpenShift Container Platform cluster.
2.1.9. Creating security group and roles in AWS
You must create security groups and roles in Amazon Web Services (AWS) for your OpenShift Container Platform cluster to use. The easiest way to create these components is to modify the provided CloudFormation template.
If you do not use the provided CloudFormation template to create your AWS infrastructure, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
Procedure
- Create a JSON file that contains the parameter values that the template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name for your cluster infrastructure that is encoded in your Ignition config files for the cluster.
- 2
- Specify the infrastructure name that you extracted from the Ignition config file metadata, which has the format<cluster-name>-<random-string>.
- 3
- The CIDR block for the VPC.
- 4
- Specify the CIDR block parameter that you used for the VPC that you defined in the formx.x.x.x/16-24.
- 5
- The private subnets that you created for your VPC.
- 6
- Specify thePrivateSubnetIdsvalue from the output of the CloudFormation template for the VPC.
- 7
- The VPC that you created for the cluster.
- 8
- Specify theVpcIdvalue from the output of the CloudFormation template for the VPC.
 
- Copy the template from the CloudFormation template for security objects section of this topic and save it as a YAML file on your computer. This template describes the security groups and roles that your cluster requires.
- Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml- 2 - --parameters file://<parameters>.json- 3 - --capabilities CAPABILITY_NAMED_IAM- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-sec. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the - StackStatusdisplays- CREATE_COMPLETE, the output displays values for the following parameters. You must provide these parameter values to the other CloudFormation templates that you run to create your cluster:- MasterSecurityGroupId- Master Security Group ID - WorkerSecurityGroupId- Worker Security Group ID - MasterInstanceProfile- Master IAM Instance Profile - WorkerInstanceProfile- Worker IAM Instance Profile 
2.1.9.1. CloudFormation template for security objects
You can use the following CloudFormation template to deploy the security objects that you need for your OpenShift Container Platform cluster.
2.1.10. RHCOS AMIs for the AWS infrastructure
You must use a valid Red Hat Enterprise Linux CoreOS (RHCOS) AMI for your Amazon Web Services (AWS) zone for your OpenShift Container Platform nodes.
| AWS zone | AWS AMI | 
|---|---|
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
| 
									 | 
									 | 
2.1.11. Creating the bootstrap node in AWS
You must create the bootstrap node in Amazon Web Services (AWS) to use during OpenShift Container Platform cluster initialization. The easiest way to create this node is to modify the provided CloudFormation template.
If you do not use the provided CloudFormation template to create your bootstrap node, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
- Create and configure DNS, load balancers, and listeners in AWS.
- Create control plane and compute roles.
Procedure
- Provide a location to serve the - bootstrap.ignIgnition config file to your cluster. This file is located in your installation directory. One way to do this is to create an S3 bucket in your cluster’s region and upload the Ignition config file to it.Important- The provided CloudFormation Template assumes that the Ignition config files for your cluster are served from an S3 bucket. If you choose to serve the files from another location, you must modify the templates. Note- The bootstrap Ignition config file does contain secrets, like X.509 keys. The following steps provide basic security for the S3 bucket. To provide additional security, you can enable an S3 bucket policy to allow only certain users, such as the OpenShift IAM user, to access objects that the bucket contains. You can avoid S3 entirely and serve your bootstrap Ignition config file from any address that the bootstrap machine can reach. - Create the bucket: - aws s3 mb s3://<cluster-name>-infra - $ aws s3 mb s3://<cluster-name>-infra- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <cluster-name>-infrais the bucket name.
 
- Upload the - bootstrap.ignIgnition config file to the bucket:- aws s3 cp bootstrap.ign s3://<cluster-name>-infra/bootstrap.ign - $ aws s3 cp bootstrap.ign s3://<cluster-name>-infra/bootstrap.ign- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the file uploaded: - aws s3 ls s3://<cluster-name>-infra/ - $ aws s3 ls s3://<cluster-name>-infra/ 2019-04-03 16:15:16 314878 bootstrap.ign- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a JSON file that contains the parameter values that the template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name for your cluster infrastructure that is encoded in your Ignition config files for the cluster.
- 2
- Specify the infrastructure name that you extracted from the Ignition config file metadata, which has the format<cluster-name>-<random-string>.
- 3
- Current Red Hat Enterprise Linux CoreOS (RHCOS) AMI to use for the bootstrap node.
- 4
- Specify a validAWS::EC2::Image::Idvalue.
- 5
- CIDR block to allow SSH access to the bootstrap node.
- 6
- Specify a CIDR block in the formatx.x.x.x/16-24.
- 7
- The public subnet that is associated with your VPC to launch the bootstrap node into.
- 8
- Specify thePublicSubnetIdsvalue from the output of the CloudFormation template for the VPC.
- 9
- The master security group ID (for registering temporary rules)
- 10
- Specify theMasterSecurityGroupIdvalue from the output of the CloudFormation template for the security group and roles.
- 11
- The VPC created resources will belong to.
- 12
- Specify theVpcIdvalue from the output of the CloudFormation template for the VPC.
- 13
- Location to fetch bootstrap Ignition config file from.
- 14
- Specify the S3 bucket and file name in the forms3://<bucket_name>/bootstrap.ign.
- 15
- Whether or not to register a network load balancer (NLB).
- 16
- Specifyyesorno. If you specifyyes, you must provide a Lambda Amazon Resource Name (ARN) value.
- 17
- The ARN for NLB IP target registration lambda group.
- 18
- Specify theRegisterNlbIpTargetsLambdavalue from the output of the CloudFormation template for DNS and load balancing.
- 19
- The ARN for external API load balancer target group.
- 20
- Specify theExternalApiTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
- 21
- The ARN for internal API load balancer target group.
- 22
- Specify theInternalApiTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
- 23
- The ARN for internal service load balancer target group.
- 24
- Specify theInternalServiceTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
 
- Copy the template from the CloudFormation template for the bootstrap machine section of this topic and save it as a YAML file on your computer. This template describes the bootstrap machine that your cluster requires.
- Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml- 2 - --parameters file://<parameters>.json- 3 - --capabilities CAPABILITY_NAMED_IAM- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-bootstrap. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - After the - StackStatusdisplays- CREATE_COMPLETE, the output displays values for the following parameters. You must provide these parameter values to the other CloudFormation templates that you run to create your cluster:- BootstrapInstanceId- The bootstrap Instance ID. - BootstrapPublicIp- The bootstrap node public IP address. - BootstrapPrivateIp- The bootstrap node private IP address. 
2.1.11.1. CloudFormation template for the bootstrap machine
You can use the following CloudFormation template to deploy the bootstrap machine that you need for your OpenShift Container Platform cluster.
2.1.12. Creating the control plane machines in AWS
You must create the control plane machines in Amazon Web Services (AWS) for your cluster to use. The easiest way to create these nodes is to modify the provided CloudFormation template.
If you do not use the provided CloudFormation template to create your control plane nodes, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
- Create and configure DNS, load balancers, and listeners in AWS.
- Create control plane and compute roles.
- Create the bootstrap machine.
Procedure
- Create a JSON file that contains the parameter values that the template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name for your cluster infrastructure that is encoded in your Ignition config files for the cluster.
- 2
- Specify the infrastructure name that you extracted from the Ignition config file metadata, which has the format<cluster-name>-<random-string>.
- 3
- CurrentRed Hat Enterprise Linux CoreOS (RHCOS) AMI to use for the control plane machines.
- 4
- Specify anAWS::EC2::Image::Idvalue.
- 5
- Whether or not to perform DNS etcd registration.
- 6
- Specifyyesorno. If you specifyyes, you must provide Hosted Zone information.
- 7
- The Route53 private zone ID to register the etcd targets with.
- 8
- Specify thePrivateHostedZoneIdvalue from the output of the CloudFormation template for DNS and load balancing.
- 9
- The Route53 zone to register the targets with.
- 10
- Specify<cluster_name>.<domain_name>where<domain_name>is the Route53 base domain that you used when you generatedinstall-config.yamlfile for the cluster. Do not include the trailing period (.) that is displayed in the AWS console.
- 11 13 15
- A subnet, preferably private, to launch the control plane machines on.
- 12 14 16
- Specify a subnet from thePrivateSubnetsvalue from the output of the CloudFormation template for DNS and load balancing.
- 17
- The master security group ID to associate with master nodes.
- 18
- Specify theMasterSecurityGroupIdvalue from the output of the CloudFormation template for the security group and roles.
- 19
- The location to fetch control plane Ignition config file from.
- 20
- Specify the generated Ignition config file location,https://api-int.<cluster_name>.<domain_name>:22623/config/master.
- 21
- The base64 encoded certificate authority string to use.
- 22
- Specify the value from themaster.ignfile that is in the installation directory. This value is the long string with the formatdata:text/plain;charset=utf-8;base64,ABC…xYz==.
- 23
- The IAM profile to associate with master nodes.
- 24
- Specify theMasterInstanceProfileparameter value from the output of the CloudFormation template for the security group and roles.
- 25
- The type of AWS instance to use for the control plane machines.
- 26
- Allowed values:- 
											m4.xlarge
- 
											m4.2xlarge
- 
											m4.4xlarge
- 
											m4.8xlarge
- 
											m4.10xlarge
- 
											m4.16xlarge
- 
											c4.2xlarge
- 
											c4.4xlarge
- 
											c4.8xlarge
- 
											r4.xlarge
- 
											r4.2xlarge
- 
											r4.4xlarge
- 
											r4.8xlarge
- r4.16xlargeImportant- If - m4instance types are not available in your region, such as with- eu-west-3, specify an- m5type, such as- m5.xlarge, instead.
 
- 
											
- 27
- Whether or not to register a network load balancer (NLB).
- 28
- Specifyyesorno. If you specifyyes, you must provide a Lambda Amazon Resource Name (ARN) value.
- 29
- The ARN for NLB IP target registration lambda group.
- 30
- Specify theRegisterNlbIpTargetsLambdavalue from the output of the CloudFormation template for DNS and load balancing.
- 31
- The ARN for external API load balancer target group.
- 32
- Specify theExternalApiTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
- 33
- The ARN for internal API load balancer target group.
- 34
- Specify theInternalApiTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
- 35
- The ARN for internal service load balancer target group.
- 36
- Specify theInternalServiceTargetGroupArnvalue from the output of the CloudFormation template for DNS and load balancing.
 
- Copy the template from the CloudFormation template for control plane machines section of this topic and save it as a YAML file on your computer. This template describes the control plane machines that your cluster requires.
- 
							If you specified an m5instance type as the value forMasterInstanceType, add that instance type to theMasterInstanceType.AllowedValuesparameter in the CloudFormation template.
- Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml- 2 - --parameters file://<parameters>.json- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-control-plane. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
2.1.12.1. CloudFormation template for control plane machines
You can use the following CloudFormation template to deploy the control plane machines that you need for your OpenShift Container Platform cluster.
2.1.13. Initializing the bootstrap node on AWS with user-provisioned infrastructure
After you create all of the required infrastructure in Amazon Web Services (AWS), you can install the cluster.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
- Create and configure DNS, load balancers, and listeners in AWS.
- Create control plane and compute roles.
- Create the bootstrap machine.
- Create the control plane machines.
- If you plan to manually manage the worker machines, create the worker machines.
Procedure
- Change to the directory that contains the installation program and run the following command: - ./openshift-install wait-for bootstrap-complete --dir=<installation_directory> \ --log-level info- $ ./openshift-install wait-for bootstrap-complete --dir=<installation_directory> \- 1 - --log-level info- 2 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If the command exits without a - FATALwarning, your production control plane has initialized.
2.1.13.1. Creating the worker nodes in AWS
You can create worker nodes in Amazon Web Services (AWS) for your cluster to use. The easiest way to manually create these nodes is to modify the provided CloudFormation template.
The CloudFormation template creates a stack that represents one worker machine. You must create a stack for each worker machine.
If you do not use the provided CloudFormation template to create your worker nodes, you must review the provided information and manually create the infrastructure. If your cluster does not initialize correctly, you might have to contact Red Hat support with your installation logs.
Prerequisites
- Configure an AWS account.
- Generate the Ignition config files for your cluster.
- Create and configure a VPC and associated subnets in AWS.
- Create and configure DNS, load balancers, and listeners in AWS.
- Create control plane and compute roles.
- Create the bootstrap machine.
- Create the control plane machines.
Procedure
- Create a JSON file that contains the parameter values that the CloudFormation template requires: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The name for your cluster infrastructure that is encoded in your Ignition config files for the cluster.
- 2
- Specify the infrastructure name that you extracted from the Ignition config file metadata, which has the format<cluster-name>-<random-string>.
- 3
- Current Red Hat Enterprise Linux CoreOS (RHCOS) AMI to use for the worker nodes.
- 4
- Specify anAWS::EC2::Image::Idvalue.
- 5
- A subnet, preferably private, to launch the worker nodes on.
- 6
- Specify a subnet from thePrivateSubnetsvalue from the output of the CloudFormation template for DNS and load balancing.
- 7
- The worker security group ID to associate with worker nodes.
- 8
- Specify theWorkerSecurityGroupIdvalue from the output of the CloudFormation template for the security group and roles.
- 9
- The location to fetch bootstrap Ignition config file from.
- 10
- Specify the generated Ignition config location,https://api-int.<cluster_name>.<domain_name>:22623/config/worker.
- 11
- Base64 encoded certificate authority string to use.
- 12
- Specify the value from theworker.ignfile that is in the installation directory. This value is the long string with the formatdata:text/plain;charset=utf-8;base64,ABC…xYz==.
- 13
- The IAM profile to associate with worker nodes.
- 14
- Specify theWorkerInstanceProfileparameter value from the output of the CloudFormation template for the security group and roles.
- 15
- The type of AWS instance to use for the control plane machines.
- 16
- Allowed values:- 
												m4.large
- 
												m4.xlarge
- 
												m4.2xlarge
- 
												m4.4xlarge
- 
												m4.8xlarge
- 
												m4.10xlarge
- 
												m4.16xlarge
- 
												c4.large
- 
												c4.xlarge
- 
												c4.2xlarge
- 
												c4.4xlarge
- 
												c4.8xlarge
- 
												r4.large
- 
												r4.xlarge
- 
												r4.2xlarge
- 
												r4.4xlarge
- 
												r4.8xlarge
- r4.16xlargeImportant- If - m4instance types are not available in your region, such as with- eu-west-3, use- m5types instead.
 
- 
												
 
- Copy the template from the CloudFormation template for worker machines section of this topic and save it as a YAML file on your computer. This template describes the networking objects and load balancers that your cluster requires.
- 
								If you specified an m5instance type as the value forWorkerInstanceType, add that instance type to theWorkerInstanceType.AllowedValuesparameter in the CloudFormation template.
- Create a worker stack. - Launch the template: Important- You must enter the command on a single line. - aws cloudformation create-stack --stack-name <name> - $ aws cloudformation create-stack --stack-name <name>- 1 - --template-body file://<template>.yaml \- 2 - --parameters file://<parameters>.json- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name for the CloudFormation stack, such as- cluster-workers. You need the name of this stack if you remove the cluster.
- 2
- <template>is the relative path to and name of the CloudFormation template YAML file that you saved.
- 3
- <parameters>is the relative path to and name of the CloudFormation parameters JSON file.
 
- Confirm that the template components exist: - aws cloudformation describe-stacks --stack-name <name> - $ aws cloudformation describe-stacks --stack-name <name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Continue to create worker stacks until you have created enough worker Machines for your cluster. Important- You must create at least two worker machines, so you must create at least two stacks that use this CloudFormation template. 
2.1.13.1.1. CloudFormation template for worker machines
You can use the following CloudFormation template to deploy the worker machines that you need for your OpenShift Container Platform cluster.
2.1.14. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
2.1.15. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
2.1.16. Approving the CSRs for your machines
When you add machines to a cluster, two pending certificates signing request (CSRs) are generated for each machine that you added. You must confirm that these CSRs are approved or, if necessary, approve them yourself.
Prerequisites
- You added machines to your cluster.
- 
							Install the jqpackage.
Procedure
- Confirm that the cluster recognizes the machines: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output lists all of the machines that you created. 
- Review the pending certificate signing requests (CSRs) and ensure that the you see a client and server request with - Pendingor- Approvedstatus for each machine that you added to the cluster:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this example, two machines are joining the cluster. You might see more approved CSRs in the list. 
- If the CSRs were not approved, after all of the pending CSRs for the machines you added are in - Pendingstatus, approve the CSRs for your cluster machines:Note- Because the CSRs rotate automatically, approve your CSRs within an hour of adding the machines to the cluster. If you do not approve them within an hour, the certificates will rotate, and more than two certificates will be present for each node. You must approve all of these certificates. After you approve the initial CSRs, the subsequent node client CSRs are automatically approved by the cluster - kube-controller-manager. You must implement a method of automatically approving the kubelet serving certificate requests.- To approve them individually, run the following command for each valid CSR: - oc adm certificate approve <csr_name> - $ oc adm certificate approve <csr_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <csr_name>is the name of a CSR from the list of current CSRs.
 
- If all the CSRs are valid, approve them all by running the following command: - oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- $ oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
2.1.17. Initial Operator configuration
After the control plane initializes, you must immediately configure some Operators so that they all become available.
Prerequisites
- Your control plane has initialized.
Procedure
- Watch the cluster components come online: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Configure the Operators that are not available.
2.1.17.1. Image registry storage configuration
						If the image-registry Operator is not available, you must configure storage for it. Instructions for both configuring a PersistentVolume, which is required for production clusters, and for configuring an empty directory as the storage location, which is available for only non-production clusters, are shown.
					
2.1.17.1.1. Configuring registry storage for AWS with user-provisioned infrastructure
During installation, your cloud credentials are sufficient to create an S3 bucket and the Registry Operator will automatically configure storage.
If the Registry Operator cannot create an S3 bucket, and automatically configure storage, you can create a S3 bucket and configure storage with the following procedure.
Prerequisites
- A cluster on AWS with user-provisioned infrastructure.
Procedure
Use the following procedure if the Registry Operator cannot create an S3 bucket and automatically configure storage.
- Set up a Bucket Lifecycle Policy to abort incomplete multipart uploads that are one day old.
- Fill in the storage configuration in - configs.imageregistry.operator.openshift.io/cluster:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
To secure your registry images in AWS, block public access to the S3 bucket.
2.1.17.1.2. Configuring storage for the image registry in non-production clusters
You must configure storage for the image registry Operator. For non-production clusters, you can set the image registry to an empty directory. If you do so, all images are lost if you restart the registry.
Procedure
- To set the image registry storage to an empty directory: - oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- $ oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Warning- Configure this option for only non-production clusters. - If you run this command before the Image Registry Operator initializes its components, the - oc patchcommand fails with the following error:- Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found - Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Wait a few minutes and run the command again. 
2.1.18. Completing an AWS installation on user-provisioned infrastructure
After you start the OpenShift Container Platform installation on Amazon Web Service (AWS) user-provisioned infrastructure, remove the bootstrap node, and wait for installation to complete.
Prerequisites
- Deploy the bootstrap node for an OpenShift Container Platform cluster on user-provisioned AWS infrastructure.
- 
							Install the ocCLI and log in.
Procedure
- Delete the bootstrap resources. If you used the CloudFormation template, delete its stack: - aws cloudformation delete-stack --stack-name <name> - $ aws cloudformation delete-stack --stack-name <name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <name>is the name of your bootstrap stack.
 
- Complete the cluster installation: - ./openshift-install --dir=<installation_directory> wait-for install-complete - $ ./openshift-install --dir=<installation_directory> wait-for install-complete- 1 - INFO Waiting up to 30m0s for the cluster to initialize...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
Chapter 3. Installing on bare metal
3.1. Installing a cluster on bare metal
In OpenShift Container Platform version 4.1, you can install a cluster on bare metal infrastructure that you provision.
While you might be able to follow this procedure to deploy a cluster on virtualized or cloud environments, you must be aware of additional considerations for non-bare metal platforms. Review the information in the guidelines for deploying OpenShift Container Platform on non-tested platforms before you attempt to install an OpenShift Container Platform cluster in such an environment.
Prerequisites
- Provision persistent storage for your cluster. To deploy a private image registry, your storage must provide ReadWriteMany access modes.
- Review details about the OpenShift Container Platform installation and update processes.
- If you use a firewall, you must configure it to access Red Hat Insights.
3.1.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
3.1.2. Machine requirements for a cluster with user-provisioned infrastructure
For a cluster that contains user-provisioned infrastructure, you must deploy all of the required machines.
3.1.2.1. Required machines
The smallest OpenShift Container Platform clusters require the following hosts:
- One bootstrap machine
- Three control plane, or master, machines
- At least two compute machines, which are also known as worker machines
The cluster requires the bootstrap machine to deploy the OpenShift Container Platform cluster on the three control plane machines. You can remove the bootstrap machine after you install the cluster.
To maintain high availability of your cluster, use separate physical hosts for these cluster machines.
The bootstrap and control plane machines must use Red Hat Enterprise Linux CoreOS (RHCOS) as the operating system.
Note that RHCOS is based on Red Hat Enterprise Linux 8 and inherits all of its hardware certifications and requirements. See Red Hat Enterprise Linux technology capabilities and limits.
3.1.2.2. Network connectivity requirements
						All the Red Hat Enterprise Linux CoreOS (RHCOS) machines require network in initramfs during boot to fetch Ignition config files from the Machine Config Server. During the initial boot, the machines require a DHCP server in order to establish a network connection to download their Ignition config files.
					
3.1.2.3. Minimum resource requirements
Each cluster machine must meet the following minimum requirements:
| Machine | Operating System | vCPU | RAM | Storage | 
|---|---|---|---|---|
| Bootstrap | RHCOS | 4 | 16 GB | 120 GB | 
| Control plane | RHCOS | 4 | 16 GB | 120 GB | 
| Compute | RHCOS or RHEL 7.6 | 2 | 8 GB | 120 GB | 
3.1.2.4. Certificate signing requests management
						Because your cluster has limited access to automatic machine management when you use infrastructure that you provision, you must provide a mechanism for approving cluster certificate signing requests (CSRs) after installation. The kube-controller-manager only approves the kubelet client CSRs. The machine-approver cannot guarantee the validity of a serving certificate that is requested by using kubelet credentials because it cannot confirm that the correct machine issued the request. You must determine and implement a method of verifying the validity of the kubelet serving certificate requests and approving them.
					
3.1.3. Creating the user-provisioned infrastructure
Before you deploy an OpenShift Container Platform cluster that uses user-provisioned infrastructure, you must create the underlying infrastructure.
Prerequistes
- Review the OpenShift Container Platform 4.x Tested Integrations page before you create the supporting infrastructure for your cluster.
Procedure
- Configure DHCP.
- Provision the required load balancers.
- Configure the ports for your machines.
- Configure DNS.
- Ensure network connectivity.
3.1.3.1. Networking requirements for user-provisioned infrastructure
						All the Red Hat Enterprise Linux CoreOS (RHCOS) machines require network in initramfs during boot to fetch Ignition config from the Machine Config Server.
					
During the initial boot, the machines require a DHCP server in order to establish a network connection to download their Ignition config files.
It is recommended to use the DHCP server to manage the machines for the cluster long-term. Ensure that the DHCP server is configured to provide persistent IP addresses and host names to the cluster machines.
The Kubernetes API server must be able to resolve the node names of the cluster machines. If the API servers and worker nodes are in different zones, you can configure a default DNS search zone to allow the API server to resolve the node names. Another acceptable approach is to always refer to hosts by their fully-qualified domain names in both the node objects and all DNS requests.
You must configure the network connectivity between machines to allow cluster components to communicate. Each machine must be able to resolve the host names of all other machines in the cluster.
| 2379-2380 | etcd server, peer, and metrics ports | 
|---|---|
| 
										 | Kubernetes API | 
| 
										 | 
										Host level services, including the node exporter on ports  | 
| 
										 | The default ports that Kubernetes reserves | 
| 
										 | openshift-sdn | 
| 
										 | Kubernetes NodePort | 
Network topology requirements
The infrastructure that you provision for your cluster must meet the following network topology requirements.
OpenShift Container Platform requires all nodes to have internet access to pull images for platform containers and provide telemetry data to Red Hat.
Load balancers
Before you install OpenShift Container Platform, you must provision two layer-4 load balancers. The API requires one load balancer and the default Ingress Controller needs the second load balancer to provide ingress to applications.
| Port | Machines | Internal | External | Description | 
|---|---|---|---|---|
| 
										 | Bootstrap and control plane. You remove the bootstrap machine from the load balancer after the bootstrap machine initializes the cluster control plane. | x | x | Kubernetes API server | 
| 
										 | Bootstrap and control plane. You remove the bootstrap machine from the load balancer after the bootstrap machine initializes the cluster control plane. | x | Machine Config server | |
| 
										 | The machines that run the Ingress router pods, compute, or worker, by default. | x | x | HTTPS traffic | 
| 
										 | The machines that run the Ingress router pods, compute, or worker by default. | x | x | HTTP traffic | 
A working configuration for the Ingress router is required for an OpenShift Container Platform cluster. You must configure the Ingress router after the control plane initializes.
3.1.3.2. User-provisioned DNS requirements
						The following DNS records are required for an OpenShift Container Platform cluster that uses user-provisioned infrastructure. In each record, <cluster_name> is the cluster name and <base_domain> is the cluster base domain that you specify in the install-config.yaml file.
					
| Component | Record | Description | 
|---|---|---|
| Kubernetes API | 
										 | This DNS record must point to the load balancer for the control plane machines. This record must be resolvable by both clients external to the cluster and from all the nodes within the cluster. | 
| 
										 | This DNS record must point to the load balancer for the control plane machines. This record must be resolvable from all the nodes within the cluster. Important The API server must be able to resolve the worker nodes by the host names that are recorded in Kubernetes. If it cannot resolve the node names, proxied API calls can fail, and you cannot retrieve logs from Pods. | |
| Routes | 
										 | A wildcard DNS record that points to the load balancer that targets the machines that run the Ingress router pods, which are the worker nodes by default. This record must be resolvable by both clients external to the cluster and from all the nodes within the cluster. | 
| etcd | 
										 | 
										OpenShift Container Platform requires DNS records for each etcd instance to point to the control plane machines that host the instances. The etcd instances are differentiated by  | 
| 
										 | 
										For each control plane machine, OpenShift Container Platform also requires a SRV DNS record for etcd server on that machine with priority  _service._proto.name. TTL class SRV priority weight port target.  | 
3.1.4. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
3.1.5. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
3.1.6. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
3.1.7. Manually creating the installation configuration file
For installations of OpenShift Container Platform that use user-provisioned infrastructure, you must manually generate your installation configuration file.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the access token for your cluster.
Procedure
- Create an installation directory to store your required installation assets in: - mkdir <installation_directory> - $ mkdir <installation_directory>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- You must create a directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. 
- Customize the following - install-config.yamlfile template and save it in the- <installation_directory>.Note- You must name this configuration file - install-config.yaml.
- Back up the - install-config.yamlfile so that you can use it to install multiple clusters.Important- The - install-config.yamlfile is consumed during the next step of the installation process. You must back it up now.
3.1.7.1. Sample install-config.yaml file for bare metal
						You can customize the install-config.yaml file to specify more details about your OpenShift Container Platform cluster’s platform or modify the values of the required parameters.
					
- 1
- The base domain of the cluster. All DNS records must be sub-domains of this base and include the cluster name.
- 2 5
- ThecontrolPlanesection is a single mapping, but the compute section is a sequence of mappings. To meet the requirements of the different data structures, the first line of thecomputesection must begin with a hyphen,-, and the first line of thecontrolPlanesection must not. Although both sections currently define a single machine pool, it is possible that future versions of OpenShift Container Platform will support defining multiple compute pools during installation. Only one control plane pool is used.
- 3 6 7
- Whether to enable or disable simultaneous multithreading, orhyperthreading. By default, simultaneous multithreading is enabled to increase the performance of your machines' cores. You can disable it by setting the parameter value toDisabled. If you disable simultanous multithreading in some cluster machines, you must disable it in all cluster machines.ImportantIf you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. 
- 4
- You must set the value of thereplicasparameter to0. This parameter controls the number of workers that the cluster creates and manages for you, which are functions that the cluster does not perform when you use user-provisioned infrastructure. You must manually deploy worker machines for the cluster to use before you finish installing OpenShift Container Platform.
- 8
- The number of control plane machines that you add to the cluster. Because the cluster uses this values as the number of etcd endpoints in the cluster, the value must match the number of control plane machines that you deploy.
- 9
- The cluster name that you specified in your DNS records.
- 10
- A block of IP addresses from which Pod IP addresses are allocated. This block must not overlap with existing physical networks. These IP addresses are used for the Pod network, and if you need to access the Pods from an external network, configure load balancers and routers to manage the traffic.
- 11
- The subnet prefix length to assign to each individual node. For example, ifhostPrefixis set to23, then each node is assigned a/23subnet out of the givencidr, which allows for 510 (2^(32 - 23) - 2) pod IPs addresses. If you are required to provide access to nodes from an external network, configure load balancers and routers to manage the traffic.
- 12
- The IP address pool to use for service IP addresses. You can enter only one IP address pool. If you need to access the services from an external network, configure load balancers and routers to manage the traffic.
- 13
- You must set the platform tonone. You cannot provide additional platform configuration variables for bare metal infrastructure.
- 14
- The pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
- 15
- The public portion of the default SSH key for thecoreuser in Red Hat Enterprise Linux CoreOS (RHCOS).NoteFor production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agentprocess uses to the installation program.
3.1.8. Creating the Ignition config files
Because you must manually start the cluster machines, you must generate the Ignition config files that the cluster needs to make its machines.
The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must complete your cluster installation and keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Obtain the Ignition config files: - ./openshift-install create ignition-configs --dir=<installation_directory> - $ ./openshift-install create ignition-configs --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
 Important- If you created an - install-config.yamlfile, specify the directory that contains it. Otherwise, specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version.- The following files are generated in the directory: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.1.9. Creating Red Hat Enterprise Linux CoreOS (RHCOS) machines
Before you install a cluster on bare metal infrastructure that you provision, you must create RHCOS machines for it to use. Follow either the steps to use an ISO image or network PXE booting to create the machines.
3.1.9.1. Creating Red Hat Enterprise Linux CoreOS (RHCOS) machines using an ISO image
Before you install a cluster on bare metal infrastructure that you provision, you must create RHCOS machines for it to use. You can use an ISO image to create the machines.
Prerequisites
- Obtain the Ignition config files for your cluster.
- Have access to an HTTP server that you can access from your computer and that the machines that you create can access.
Procedure
- Upload the control plane, compute, and bootstrap Ignition config files that the installation program created to your HTTP server. Note the URLs of these files.
- Obtain the RHCOS images that are required for your preferred method of installing operating system instances from the Product Downloads page on the Red Hat customer portal or the RHCOS image mirror page. Important- The RHCOS images might not change with every release of OpenShift Container Platform. You must download images with the highest version that is less than or equal to the OpenShift Container Platform version that you install. Use the image versions that match your OpenShift Container Platform version if they are available. - You must download the ISO file and either the BIOS or UEFI file. Those file names resemble the following examples: - 
										ISO: rhcos-<version>-<architecture>-installer.iso
- 
										Compressed metal BIOS: rhcos-<version>-<architecture>-metal-bios.raw.gz
- 
										Compressed metal UEFI: rhcos-<version>-<architecture>-metal-uefi.raw.gz
 
- 
										ISO: 
- Upload either the BIOS or UEFI RHCOS image file to your HTTP server and note its URL.
- Use the ISO to start the RHCOS installation. Use one of the following installation options: - Burn the ISO image to a disk and boot it directly.
- Use ISO redirection via a LOM interface.
 
- 
								After the instance boots, press the TABorEkey to edit the kernel command line.
- Add the parameters to the kernel command line: - coreos.inst=yes coreos.inst.install_dev=sda coreos.inst.image_url=<bare_metal_image_URL> coreos.inst.ignition_url=http://example.com/config.ign - coreos.inst=yes coreos.inst.install_dev=sda- 1 - coreos.inst.image_url=<bare_metal_image_URL>- 2 - coreos.inst.ignition_url=http://example.com/config.ign- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Press Enter to complete the installation. After RHCOS installs, the system reboots. After the system reboots, it applies the Ignition config file that you specified.
- Continue to create the machines for your cluster. Important- You must create the bootstrap and control plane machines at this time. Because some pods are deployed on compute machines by default, also create at least two compute machines before you install the cluster. 
3.1.9.2. Creating Red Hat Enterprise Linux CoreOS (RHCOS) machines by PXE or iPXE booting
Before you install a cluster on bare metal infrastructure that you provision, you must create RHCOS machines for it to use. You can use PXE or iPXE booting to create the machines.
Prerequisites
- Obtain the Ignition config files for your cluster.
- Configure suitable PXE or iPXE infrastructure.
- Have access to an HTTP server that you can access from your computer.
Procedure
- Upload the master, worker, and bootstrap Ignition config files that the installation program created to your HTTP server. Note the URLs of these files.
- Obtain the RHCOS ISO image, compressed metal BIOS, - kerneland- initramfsfiles from the Product Downloads page on the Red Hat customer portal or the RHCOS image mirror page.Important- The RHCOS images might not change with every release of OpenShift Container Platform. You must download images with the highest version that is less than or equal to the OpenShift Container Platform version that you install. Use the image versions that match your OpenShift Container Platform version if they are available. - The file names contain the OpenShift Container Platform version number. They resemble the following examples: - 
										ISO: rhcos-<version>-<architecture>-installer.iso
- 
										Compressed metal BIOS: rhcos-<version>-<architecture>-metal-bios.raw.gz
- 
										kernel:rhcos-<version>-<architecture>-installer-kernel
- 
										initramfs:rhcos-<version>-<architecture>-installer-initramfs.img
 
- 
										ISO: 
- 
								Upload the compressed metal BIOS file and the kernelandinitramfsfiles to your HTTP server.
- Configure the network boot infrastructure so that the machines boot from their local disks after RHCOS is installed on them.
- Configure PXE or iPXE installation for the RHCOS images. - Modify one of the following example menu entries for your environment and verify that the image and Ignition files are properly accessible: - For PXE: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the location of thekernelfile that you uploaded to your HTTP server.
- 2
- If you use multiple NICs, specify a single interface in theipoption. For example, to use DHCP on a NIC that is namedeno1, setip=eno1:dhcp.
- 3
- Specify locations of the RHCOS files that you uploaded to your HTTP server. Theinitrdparameter value is the location of theinitramfsfile, thecoreos.inst.image_urlparameter value is the location of the compressed metal BIOS file, and thecoreos.inst.ignition_urlparameter value is the location of the bootstrap Ignition config file.
 
- For iPXE: - kernel http://<HTTP_server>/rhcos-<version>-<architecture>-installer-kernel ip=dhcp rd.neednet=1 initrd=http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img console=tty0 console=ttyS0 coreos.inst=yes coreos.inst.install_dev=sda coreos.inst.image_url=http://<HTTP_server>/rhcos-<version>-<architecture>-metal-bios.raw.gz coreos.inst.ignition_url=http://<HTTP_server>/bootstrap.ign initrd http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img boot - kernel http://<HTTP_server>/rhcos-<version>-<architecture>-installer-kernel ip=dhcp rd.neednet=1 initrd=http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img console=tty0 console=ttyS0 coreos.inst=yes coreos.inst.install_dev=sda coreos.inst.image_url=http://<HTTP_server>/rhcos-<version>-<architecture>-metal-bios.raw.gz coreos.inst.ignition_url=http://<HTTP_server>/bootstrap.ign- 1 - 2 - initrd http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img- 3 - boot- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify locations of the RHCOS files that you uploaded to your HTTP server. Thekernelparameter value is the location of thekernelfile, theinitrdparameter value is the location of theinitramfsfile, thecoreos.inst.image_urlparameter value is the location of the compressed metal BIOS file, and thecoreos.inst.ignition_urlparameter value is the location of the bootstrap Ignition config file.
- 2
- If you use multiple NICs, specify a single interface in theipoption. For example, to use DHCP on a NIC that is namedeno1, setip=eno1:dhcp.
- 3
- Specify the location of theinitramfsfile that you uploaded to your HTTP server.
 
 
- If you use UEFI, edit the included - grub.conffile that is included in the ISO that you downloaded to include the following installation options:- menuentry 'Install Red Hat Enterprise Linux CoreOS' --class fedora --class gnu-linux --class gnu --class os { linux /images/vmlinuz nomodeset rd.neednet=1 coreos.inst=yes coreos.inst.install_dev=sda coreos.inst.image_url=http://<HTTP_server>/rhcos-<version>-<architecture>-metal-uefi.raw.gz coreos.inst.ignition_url=http://<HTTP_server>/bootstrap.ign initrd http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img }- menuentry 'Install Red Hat Enterprise Linux CoreOS' --class fedora --class gnu-linux --class gnu --class os { linux /images/vmlinuz nomodeset rd.neednet=1 coreos.inst=yes coreos.inst.install_dev=sda coreos.inst.image_url=http://<HTTP_server>/rhcos-<version>-<architecture>-metal-uefi.raw.gz coreos.inst.ignition_url=http://<HTTP_server>/bootstrap.ign- 1 - initrd http://<HTTP_server>/rhcos-<version>-<architecture>-installer-initramfs.img- 2 - }- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For thecoreos.inst.image_urlparameter value, specify the location of the compressed metal UEFI file that you uploaded to your HTTP server. For thecoreos.inst.ignition_url, specify the location of the bootstrap Ignition config file that you uploaded to your HTTP server.
- 2
- Specify the location of theinitramfsfile that you uploaded to your HTTP server.
 
- Continue to create the machines for your cluster. Important- You must create the bootstrap and control plane machines at this time. Because some pods are deployed on compute machines by default, also create at least two compute machine before you install the cluster. 
3.1.10. Creating the cluster
To create the OpenShift Container Platform cluster, you wait for the bootstrap process to complete on the machines that you provisoned by using the Ignition config files that you generated with the installation program.
Prerequisites
- Create the required infrastructure for the cluster.
- You obtained the installation program and generated the Ignition config files for your cluster.
- You used the Ignition config files to create RHCOS machines for your cluster.
- Your machines have direct internet access.
Procedure
- Monitor the bootstrap process: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The command succeeds when the Kubernetes API server signals that it has been bootstrapped on the control plane machines. 
- After bootstrap process is complete, remove the bootstrap machine from the load balancer. Important- You must remove the bootstrap machine from the load balancer at this point. You can also remove or reformat the machine itself. 
3.1.11. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
3.1.12. Approving the CSRs for your machines
When you add machines to a cluster, two pending certificates signing request (CSRs) are generated for each machine that you added. You must confirm that these CSRs are approved or, if necessary, approve them yourself.
Prerequisites
- You added machines to your cluster.
- 
							Install the jqpackage.
Procedure
- Confirm that the cluster recognizes the machines: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output lists all of the machines that you created. 
- Review the pending certificate signing requests (CSRs) and ensure that the you see a client and server request with - Pendingor- Approvedstatus for each machine that you added to the cluster:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this example, two machines are joining the cluster. You might see more approved CSRs in the list. 
- If the CSRs were not approved, after all of the pending CSRs for the machines you added are in - Pendingstatus, approve the CSRs for your cluster machines:Note- Because the CSRs rotate automatically, approve your CSRs within an hour of adding the machines to the cluster. If you do not approve them within an hour, the certificates will rotate, and more than two certificates will be present for each node. You must approve all of these certificates. After you approve the initial CSRs, the subsequent node client CSRs are automatically approved by the cluster - kube-controller-manager. You must implement a method of automatically approving the kubelet serving certificate requests.- To approve them individually, run the following command for each valid CSR: - oc adm certificate approve <csr_name> - $ oc adm certificate approve <csr_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <csr_name>is the name of a CSR from the list of current CSRs.
 
- If all the CSRs are valid, approve them all by running the following command: - oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- $ oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
3.1.13. Initial Operator configuration
After the control plane initializes, you must immediately configure some Operators so that they all become available.
Prerequisites
- Your control plane has initialized.
Procedure
- Watch the cluster components come online: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Configure the Operators that are not available.
3.1.13.1. Image registry storage configuration
						If the image-registry Operator is not available, you must configure storage for it. Instructions for both configuring a PersistentVolume, which is required for production clusters, and for configuring an empty directory as the storage location, which is available for only non-production clusters, are shown.
					
3.1.13.1.1. Configuring registry storage for bare metal
As a cluster administrator, following installation you must configure your registry to use storage.
Prerequisites
- Cluster administrator permissions.
- A cluster on bare metal.
- 
									A provisioned persistent volume (PV) with ReadWriteManyaccess mode, such asNFS.
- Must have "100Gi" capacity.
Procedure
- 
									To configure your registry to use storage, change the spec.storage.pvcin theconfigs.imageregistry/clusterresource.
- Verify you do not have a registry pod: - oc get pod -n openshift-image-registry - $ oc get pod -n openshift-image-registry- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
								If the storage type is emptyDIR, the replica number can not be greater than 1. If the storage type is NFS, and you want to scale up the registry Pod by setting replica>1 you must enable the no_wdelay mount option. For example:
							
cat /etc/exports /mnt/data *(rw,sync,no_wdelay,no_root_squash,insecure,fsid=0) sh-4.3# exportfs -rv exporting *:/mnt/data
# cat /etc/exports
/mnt/data *(rw,sync,no_wdelay,no_root_squash,insecure,fsid=0)
sh-4.3# exportfs -rv
exporting *:/mnt/data- Check the registry configuration: - oc edit configs.imageregistry.operator.openshift.io - $ oc edit configs.imageregistry.operator.openshift.io storage: pvc: claim:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Leave the - claimfield blank to allow the automatic creation of an- image-registry-storagePVC.
- Check the - clusteroperatorstatus:- oc get clusteroperator image-registry - $ oc get clusteroperator image-registry- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
3.1.13.1.2. Configuring storage for the image registry in non-production clusters
You must configure storage for the image registry Operator. For non-production clusters, you can set the image registry to an empty directory. If you do so, all images are lost if you restart the registry.
Procedure
- To set the image registry storage to an empty directory: - oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- $ oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Warning- Configure this option for only non-production clusters. - If you run this command before the Image Registry Operator initializes its components, the - oc patchcommand fails with the following error:- Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found - Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Wait a few minutes and run the command again. 
3.1.14. Completing installation on user-provisioned infrastructure
After you complete the Operator configuration, you can finish installing the cluster on infrastructure that you provide.
Prerequisites
- Your control plane has initialized.
- You have completed the initial Operator configuration.
Procedure
- Confirm that all the cluster components are online: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - When all of the cluster Operators are - AVAILABLE, you can complete the installation.
- Monitor for cluster completion: - ./openshift-install --dir=<installation_directory> wait-for install-complete - $ ./openshift-install --dir=<installation_directory> wait-for install-complete- 1 - INFO Waiting up to 30m0s for the cluster to initialize...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 - The command succeeds when the Cluster Version Operator finishes deploying the OpenShift Container Platform cluster from Kubernetes API server. Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. 
- Confirm that the Kubernetes API server is communicating with the Pods. - To view a list of all Pods, use the following command: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- View the logs for a Pod that is listed in the output of the previous command by using the following command: - oc logs <pod_name> -n <namespace> - $ oc logs <pod_name> -n <namespace>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the Pod name and namespace, as shown in the output of the previous command.
 - If the Pod logs display, the Kubernetes API server can communicate with the cluster machines. 
 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
Chapter 4. Installing on vSphere
4.1. Installing a cluster on vSphere
In OpenShift Container Platform version 4.1, you can install a cluster on VMware vSphere infrastructure that you provision.
Prerequisites
- Provision persistent storage for your cluster. To deploy a private image registry, your storage must provide ReadWriteMany access modes.
- Review details about the OpenShift Container Platform installation and update processes.
- If you use a firewall, you must configure it to access Red Hat Insights.
4.1.1. Internet and Telemetry access for OpenShift Container Platform
In OpenShift Container Platform 4.1, Telemetry is the component that provides metrics about cluster health and the success of updates. To perform subscription management, including legally entitling your purchase from Red Hat, you must use the Telemetry service and access the Red Hat OpenShift Cluster Manager page.
Because there is no disconnected subscription management, you cannot both opt out of sending data back to Red Hat and entitle your purchase. Support for disconnected subscription management might be added in future releases of OpenShift Container Platform
Your machines must have direct internet access to install the cluster.
You must have internet access to:
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site to download the installation program
- Access Quay.io to obtain the packages that are required to install your cluster
- Obtain the packages that are required to perform cluster updates
- Access Red Hat’s software as a service page to perform subscription management
4.1.2. VMware vSphere infrastructure requirements
You must install the OpenShift Container Platform cluster on a VMware vSphere version 6.5 or 6.7U2 or later instance.
VMware recommends using vSphere Version 6.7 U2 or later with your OpenShift Container Platform cluster. vSphere 6.7U2 includes:
- Support for VMware NSX-T
- Support for vSAN, VMFS and NFS, using the in-tree VCP
While vSphere 6.5 with Hardware version 13 is supported, OpenShift Container Platform clusters are subject to the following restrictions:
- NSX-T SDN is not supported.
- You must use another SDN or storage provider that OpenShift Container Platform supports.
If you use a vSphere version 6.5 instance, consider upgrading to 6.7U2 before you install OpenShift Container Platform.
You must ensure that the time on your ESXi hosts is synchronized before you install OpenShift Container Platform. See Edit Time Configuration for a Host in the VMware documentation.
4.1.3. Machine requirements for a cluster with user-provisioned infrastructure
For a cluster that contains user-provisioned infrastructure, you must deploy all of the required machines.
4.1.3.1. Required machines
The smallest OpenShift Container Platform clusters require the following hosts:
- One bootstrap machine
- Three control plane, or master, machines
- At least two compute machines, which are also known as worker machines
The cluster requires the bootstrap machine to deploy the OpenShift Container Platform cluster on the three control plane machines. You can remove the bootstrap machine after you install the cluster.
To maintain high availability of your cluster, use separate physical hosts for these cluster machines.
The bootstrap and control plane machines must use Red Hat Enterprise Linux CoreOS (RHCOS) as the operating system.
Note that RHCOS is based on Red Hat Enterprise Linux 8 and inherits all of its hardware certifications and requirements. See Red Hat Enterprise Linux technology capabilities and limits.
4.1.3.2. Network connectivity requirements
						All the Red Hat Enterprise Linux CoreOS (RHCOS) machines require network in initramfs during boot to fetch Ignition config files from the Machine Config Server. During the initial boot, the machines require a DHCP server in order to establish a network connection to download their Ignition config files.
					
4.1.3.3. Minimum resource requirements
Each cluster machine must meet the following minimum requirements:
| Machine | Operating System | vCPU | RAM | Storage | 
|---|---|---|---|---|
| Bootstrap | RHCOS | 4 | 16 GB | 120 GB | 
| Control plane | RHCOS | 4 | 16 GB | 120 GB | 
| Compute | RHCOS or RHEL 7.6 | 2 | 8 GB | 120 GB | 
4.1.3.4. Certificate signing requests management
						Because your cluster has limited access to automatic machine management when you use infrastructure that you provision, you must provide a mechanism for approving cluster certificate signing requests (CSRs) after installation. The kube-controller-manager only approves the kubelet client CSRs. The machine-approver cannot guarantee the validity of a serving certificate that is requested by using kubelet credentials because it cannot confirm that the correct machine issued the request. You must determine and implement a method of verifying the validity of the kubelet serving certificate requests and approving them.
					
4.1.4. Creating the user-provisioned infrastructure
Before you deploy an OpenShift Container Platform cluster that uses user-provisioned infrastructure, you must create the underlying infrastructure.
Prerequistes
- Review the OpenShift Container Platform 4.x Tested Integrations page before you create the supporting infrastructure for your cluster.
Procedure
- Configure DHCP.
- Provision the required load balancers.
- Configure the ports for your machines.
- Configure DNS.
- Ensure network connectivity.
4.1.4.1. Networking requirements for user-provisioned infrastructure
						All the Red Hat Enterprise Linux CoreOS (RHCOS) machines require network in initramfs during boot to fetch Ignition config from the Machine Config Server.
					
During the initial boot, the machines require a DHCP server in order to establish a network connection to download their Ignition config files.
It is recommended to use the DHCP server to manage the machines for the cluster long-term. Ensure that the DHCP server is configured to provide persistent IP addresses and host names to the cluster machines.
The Kubernetes API server must be able to resolve the node names of the cluster machines. If the API servers and worker nodes are in different zones, you can configure a default DNS search zone to allow the API server to resolve the node names. Another acceptable approach is to always refer to hosts by their fully-qualified domain names in both the node objects and all DNS requests.
You must configure the network connectivity between machines to allow cluster components to communicate. Each machine must be able to resolve the host names of all other machines in the cluster.
| 2379-2380 | etcd server, peer, and metrics ports | 
|---|---|
| 
										 | Kubernetes API | 
| 
										 | 
										Host level services, including the node exporter on ports  | 
| 
										 | The default ports that Kubernetes reserves | 
| 
										 | openshift-sdn | 
| 
										 | Kubernetes NodePort | 
Network topology requirements
The infrastructure that you provision for your cluster must meet the following network topology requirements.
OpenShift Container Platform requires all nodes to have internet access to pull images for platform containers and provide telemetry data to Red Hat.
Load balancers
Before you install OpenShift Container Platform, you must provision two layer-4 load balancers. The API requires one load balancer and the default Ingress Controller needs the second load balancer to provide ingress to applications.
| Port | Machines | Internal | External | Description | 
|---|---|---|---|---|
| 
										 | Bootstrap and control plane. You remove the bootstrap machine from the load balancer after the bootstrap machine initializes the cluster control plane. | x | x | Kubernetes API server | 
| 
										 | Bootstrap and control plane. You remove the bootstrap machine from the load balancer after the bootstrap machine initializes the cluster control plane. | x | Machine Config server | |
| 
										 | The machines that run the Ingress router pods, compute, or worker, by default. | x | x | HTTPS traffic | 
| 
										 | The machines that run the Ingress router pods, compute, or worker by default. | x | x | HTTP traffic | 
A working configuration for the Ingress router is required for an OpenShift Container Platform cluster. You must configure the Ingress router after the control plane initializes.
Ethernet adaptor hardware address requirements
When provisioning VMs for the cluster, the ethernet interfaces configured for each VM must use a MAC address from the VMware Organizationally Unique Identifier (OUI) allocation ranges:
- 
								00:05:69:00:00:00to00:05:69:FF:FF:FF
- 
								00:0c:29:00:00:00to00:0c:29:FF:FF:FF
- 
								00:1c:14:00:00:00to00:1c:14:FF:FF:FF
- 
								00:50:56:00:00:00to00:50:56:FF:FF:FF
If a MAC address outside the VMware OUI is used, the cluster installation will not succeed.
4.1.4.2. User-provisioned DNS requirements
						The following DNS records are required for an OpenShift Container Platform cluster that uses user-provisioned infrastructure. In each record, <cluster_name> is the cluster name and <base_domain> is the cluster base domain that you specify in the install-config.yaml file.
					
| Component | Record | Description | 
|---|---|---|
| Kubernetes API | 
										 | This DNS record must point to the load balancer for the control plane machines. This record must be resolvable by both clients external to the cluster and from all the nodes within the cluster. | 
| 
										 | This DNS record must point to the load balancer for the control plane machines. This record must be resolvable from all the nodes within the cluster. Important The API server must be able to resolve the worker nodes by the host names that are recorded in Kubernetes. If it cannot resolve the node names, proxied API calls can fail, and you cannot retrieve logs from Pods. | |
| Routes | 
										 | A wildcard DNS record that points to the load balancer that targets the machines that run the Ingress router pods, which are the worker nodes by default. This record must be resolvable by both clients external to the cluster and from all the nodes within the cluster. | 
| etcd | 
										 | 
										OpenShift Container Platform requires DNS records for each etcd instance to point to the control plane machines that host the instances. The etcd instances are differentiated by  | 
| 
										 | 
										For each control plane machine, OpenShift Container Platform also requires a SRV DNS record for etcd server on that machine with priority  _service._proto.name. TTL class SRV priority weight port target.  | 
4.1.5. Generating an SSH private key and adding it to the agent
					For production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agent process uses to the installer.
				
					You can use this key to SSH into the master nodes as the user core. When you deploy the cluster, the key is added to the core user’s ~/.ssh/authorized_keys list.
				
You must use a local key, not one that you configured with platform-specific approaches such as AWS key pairs.
Procedure
- If you do not have an SSH key that is configured for password-less authentication on your computer, create one. For example, on a computer that uses a Linux operating system, run the following command: - ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- $ ssh-keygen -t rsa -b 4096 -N '' \ -f <path>/<file_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name, such as~/.ssh/id_rsa, of the SSH key.
 - Running this command generates an SSH key that does not require a password in the location that you specified. 
- Start the - ssh-agentprocess as a background task:- eval "$(ssh-agent -s)" - $ eval "$(ssh-agent -s)" Agent pid 31874- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Add your SSH private key to the - ssh-agent:- ssh-add <path>/<file_name> - $ ssh-add <path>/<file_name>- 1 - Identity added: /home/<you>/<path>/<file_name> (<computer_name>)- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the path and file name for your SSH private key, such as~/.ssh/id_rsa
 
Next steps
When you install OpenShift Container Platform, provide the SSH public key to the installer. If you install a cluster on infrastructure that you provision, you must provide this key to your cluster’s machines.
4.1.6. Obtaining the installation program
Before you install OpenShift Container Platform, download the installation file on a local computer.
Prerequisites
- You must install the cluster from a computer that uses Linux or macOS.
- You need 300 MB of local disk space to download the installation program.
Procedure
- Access the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site. If you have a Red Hat account, log in with your credentials. If you do not, create an account.
- Navigate to the page for your installation type, download the installation program for your operating system, and place the file in the directory where you will store the installation configuration files. Important- The installation program creates several files on the computer that you use to install your cluster. You must keep both the installation program and the files that the installation program creates after you finish installing the cluster. 
- Extract the installation program. For example, on a computer that uses a Linux operating system, run the following command: - tar xvf <installation_program>.tar.gz - $ tar xvf <installation_program>.tar.gz- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- 
							From the Pull Secret page on the Red Hat OpenShift Cluster Manager site, download your installation pull secret as a .txtfile or copy it to your clipboard. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
4.1.7. Manually creating the installation configuration file
For installations of OpenShift Container Platform that use user-provisioned infrastructure, you must manually generate your installation configuration file.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the access token for your cluster.
Procedure
- Create an installation directory to store your required installation assets in: - mkdir <installation_directory> - $ mkdir <installation_directory>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Important- You must create a directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version. 
- Customize the following - install-config.yamlfile template and save it in the- <installation_directory>.Note- You must name this configuration file - install-config.yaml.
- Back up the - install-config.yamlfile so that you can use it to install multiple clusters.Important- The - install-config.yamlfile is consumed during the next step of the installation process. You must back it up now.
4.1.7.1. Sample install-config.yaml file for VMware vSphere
						You can customize the install-config.yaml file to specify more details about your OpenShift Container Platform cluster’s platform or modify the values of the required parameters.
					
- 1
- The base domain of the cluster. All DNS records must be sub-domains of this base and include the cluster name.
- 2 5
- ThecontrolPlanesection is a single mapping, but the compute section is a sequence of mappings. To meet the requirements of the different data structures, the first line of thecomputesection must begin with a hyphen,-, and the first line of thecontrolPlanesection must not. Although both sections currently define a single machine pool, it is possible that future versions of OpenShift Container Platform will support defining multiple compute pools during installation. Only one control plane pool is used.
- 3 6
- Whether to enable or disable simultaneous multithreading, orhyperthreading. By default, simultaneous multithreading is enabled to increase the performance of your machines' cores. You can disable it by setting the parameter value toDisabled. If you disable simultanous multithreading in some cluster machines, you must disable it in all cluster machines.ImportantIf you disable simultaneous multithreading, ensure that your capacity planning accounts for the dramatically decreased machine performance. Your machines must use at least 8 CPUs and 32 GB of RAM if you disable simultaneous multithreading. 
- 4
- You must set the value of thereplicasparameter to0. This parameter controls the number of workers that the cluster creates and manages for you, which are functions that the cluster does not perform when you use user-provisioned infrastructure. You must manually deploy worker machines for the cluster to use before you finish installing OpenShift Container Platform.
- 7
- The number of control plane machines that you add to the cluster. Because the cluster uses this values as the number of etcd endpoints in the cluster, the value must match the number of control plane machines that you deploy.
- 8
- The cluster name that you specified in your DNS records.
- 9
- The fully-qualified host name or IP address of the vCenter server.
- 10
- The name of the user for accessing the server. This user must have at least the roles and privileges that are required for dynamic persistent volume provisioning in vSphere.
- 11
- The password associated with the vSphere user.
- 12
- The vSphere datacenter.
- 13
- The default vSphere datastore to use.
- 14
- The pull secret that you obtained from the Pull Secret page on the Red Hat OpenShift Cluster Manager site. This pull secret allows you to authenticate with the services that are provided by the included authorities, including Quay.io, which serves the container images for OpenShift Container Platform components.
- 15
- The public portion of the default SSH key for thecoreuser in Red Hat Enterprise Linux CoreOS (RHCOS).NoteFor production OpenShift Container Platform clusters on which you want to perform installation debugging or disaster recovery, you must provide an SSH key that your ssh-agentprocess uses to the installer.
4.1.8. Creating the Ignition config files
Because you must manually start the cluster machines, you must generate the Ignition config files that the cluster needs to make its machines.
The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must complete your cluster installation and keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished.
Prerequisites
- Obtain the OpenShift Container Platform installation program and the pull secret for your cluster.
Procedure
- Obtain the Ignition config files: - ./openshift-install create ignition-configs --dir=<installation_directory> - $ ./openshift-install create ignition-configs --dir=<installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the directory name to store the files that the installation program creates.
 Important- If you created an - install-config.yamlfile, specify the directory that contains it. Otherwise, specify an empty directory. Some installation assets, like bootstrap X.509 certificates have short expiration intervals, so you must not reuse an installation directory. If you want to reuse individual files from another cluster installation, you can copy them into your directory. However, the file names for the installation assets might change between releases. Use caution when copying installation files from an earlier OpenShift Container Platform version.- The following files are generated in the directory: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.1.9. Creating Red Hat Enterprise Linux CoreOS (RHCOS) machines in vSphere
Before you install a cluster that contains user-provisioned infrastructure on VMware vSphere, you must create RHCOS machines on vSphere hosts for it to use.
Prerequisites
- Obtain the Ignition config files for your cluster.
- Have access to an HTTP server that you can access from your computer and that the machines that you create can access.
- Create a vSphere cluster.
Procedure
- Upload the bootstrap Ignition config file, which is named - <installation_directory>/bootstrap.ign, that the installation program created to your HTTP server. Note the URL of this file.- You must host the bootstrap Ignition config file because it is too large to fit in a vApp property. 
- Save the following secondary Ignition config file for your bootstrap node to your computer as - <installation_directory>/append-bootstrap.ign.- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the URL of the bootstrap Ignition config file that you hosted.
 - When you create the Virtual Machine (VM) for the bootstrap machine, you use this Ignition config file. 
- Convert the master, worker, and secondary bootstrap Ignition config files to Base64 encoding. - For example, if you use a Linux operating system, you can use the - base64command to encode the files.- base64 -w0 <installation_directory>/master.ign > <installation_directory>/master.64 base64 -w0 <installation_directory>/worker.ign > <installation_directory>/worker.64 base64 -w0 <installation_directory>/append-bootstrap.ign > <installation_directory>/append-bootstrap.64 - $ base64 -w0 <installation_directory>/master.ign > <installation_directory>/master.64 $ base64 -w0 <installation_directory>/worker.ign > <installation_directory>/worker.64 $ base64 -w0 <installation_directory>/append-bootstrap.ign > <installation_directory>/append-bootstrap.64- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Obtain the RHCOS OVA image from the Product Downloads page on the Red Hat customer portal or the RHCOS image mirror page. Important- The RHCOS images might not change with every release of OpenShift Container Platform. You must download an image with the highest version that is less than or equal to the OpenShift Container Platform version that you install. Use the image version that matches your OpenShift Container Platform version if it is available. - The file name contains the OpenShift Container Platform version number in the format - rhcos-<version>-<architecture>-vmware.ova.
- In the vSphere Client, create a folder in your datacenter to store your VMs. - Click the VMs and Templates view.
- Right-click the name of your datacenter.
- Click New Folder → New VM and Template Folder.
- 
									In the window that is displayed, enter the folder name. The folder name must match the cluster name that you specified in the install-config.yamlfile.
 
- In the vSphere Client, create a template for the OVA image. Note- In the following steps, you use the same template for all of your cluster machines and provide the location for the Ignition config file for that machine type when you provision the VMs. - From the Hosts and Clusters tab, right-click your cluster’s name and click Deploy OVF Template.
- On the Select an OVF tab, specify the name of the RHCOS OVA file that you downloaded.
- On the Select a name and folder tab, set a Virtual machine name, such as RHCOS, click the name of your vSphere cluster, and select the folder you created in the previous step.
- On the Select a compute resource tab, click the name of your vSphere cluster.
- On the Select storage tab, configure the storage options for your VM. - Select Thin Provision.
- 
											Select the datastore that you specified in your install-config.yamlfile.
 
- On the Select network tab, specify the network that you configured for the cluster, if available.
- If you plan to use the same template for all cluster machine types, do not specify values on the Customize template tab.
 
- After the template deploys, deploy a VM for a machine in the cluster. - Right-click the template’s name and click Clone → Clone to Virtual Machine.
- 
									On the Select a name and folder tab, specify a name for the VM. You might include the machine type in the name, such as control-plane-0orcompute-1.
- On the Select a name and folder tab, select the name of the folder that you created for the cluster.
- On the Select a compute resource tab, select the name of a host in your datacenter.
- Optional: On the Select storage tab, customize the storage options.
- On the Select clone options, select Customize this virtual machine’s hardware.
- On the Customize hardware tab, click VM Options → Advanced. - Optional: In the event of cluster performance issues, from the Latency Sensitivity list, select High.
- Click Edit Configuration, and on the Configuration Parameters window, click Add Configuration Params. Define the following parameter names and values: - 
													guestinfo.ignition.config.data: Paste the contents of the base64-encoded Ignition config file for this machine type.
- 
													guestinfo.ignition.config.data.encoding: Specifybase64.
- 
													disk.EnableUUID: SpecifyTRUE.
 
- 
													
- Alternatively, prior to powering on the virtual machine add via vApp properties: - Navigate to a virtual machine from the vCenter Server inventory.
- On the Configure tab, expand Settings and select vApp options.
- Scroll down and under Properties apply the configurations from above.
 
 
- In the Virtual Hardware panel of the Customize hardware tab, modify the specified values as required. Ensure that the amount of RAM, CPU, and disk storage meets the minimum requirements for the machine type.
- Complete the configuration and power on the VM.
 
- Create the rest of the machines for your cluster by following the preceding steps for each machine. Important- You must create the bootstrap and control plane machines at this time. Because some pods are deployed on compute machines by default, also create at least two compute machine before you install the cluster. 
4.1.10. Installing the OpenShift Command-line Interface
					You can download and install the OpenShift Command-line Interface (CLI), commonly known as oc.
				
						If you installed an earlier version of oc, you cannot use it to complete all of the commands in OpenShift Container Platform 4.1. You must download and install the new version of oc.
					
Procedure
- From the Infrastructure Provider page on the Red Hat OpenShift Cluster Manager site, navigate to the page for your installation type and click Download Command-line Tools.
- From the site that is displayed, download the compressed file for your operating system. Note- You can install - ocon Linux, Windows, or macOS.
- Extract the compressed file and place it in a directory that is on your PATH.
4.1.11. Creating the cluster
To create the OpenShift Container Platform cluster, you wait for the bootstrap process to complete on the machines that you provisoned by using the Ignition config files that you generated with the installation program.
Prerequisites
- Create the required infrastructure for the cluster.
- You obtained the installation program and generated the Ignition config files for your cluster.
- You used the Ignition config files to create RHCOS machines for your cluster.
- Your machines have direct internet access.
Procedure
- Monitor the bootstrap process: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The command succeeds when the Kubernetes API server signals that it has been bootstrapped on the control plane machines. 
- After bootstrap process is complete, remove the bootstrap machine from the load balancer. Important- You must remove the bootstrap machine from the load balancer at this point. You can also remove or reformat the machine itself. 
4.1.12. Logging in to the cluster
					You can log in to your cluster as a default system user by exporting the cluster kubeconfig file. The kubeconfig file contains information about the cluster that is used by the CLI to connect a client to the correct cluster and API server. The file is specific to a cluster and is created during OpenShift Container Platform installation.
				
Prerequisites
- Deploy an OpenShift Container Platform cluster.
- 
							Install the ocCLI.
Procedure
- Export the - kubeadmincredentials:- export KUBECONFIG=<installation_directory>/auth/kubeconfig oc whoami - $ export KUBECONFIG=<installation_directory>/auth/kubeconfig- 1 - $ oc whoami system:admin- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 
4.1.13. Approving the CSRs for your machines
When you add machines to a cluster, two pending certificates signing request (CSRs) are generated for each machine that you added. You must confirm that these CSRs are approved or, if necessary, approve them yourself.
Prerequisites
- You added machines to your cluster.
- 
							Install the jqpackage.
Procedure
- Confirm that the cluster recognizes the machines: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output lists all of the machines that you created. 
- Review the pending certificate signing requests (CSRs) and ensure that the you see a client and server request with - Pendingor- Approvedstatus for each machine that you added to the cluster:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - In this example, two machines are joining the cluster. You might see more approved CSRs in the list. 
- If the CSRs were not approved, after all of the pending CSRs for the machines you added are in - Pendingstatus, approve the CSRs for your cluster machines:Note- Because the CSRs rotate automatically, approve your CSRs within an hour of adding the machines to the cluster. If you do not approve them within an hour, the certificates will rotate, and more than two certificates will be present for each node. You must approve all of these certificates. After you approve the initial CSRs, the subsequent node client CSRs are automatically approved by the cluster - kube-controller-manager. You must implement a method of automatically approving the kubelet serving certificate requests.- To approve them individually, run the following command for each valid CSR: - oc adm certificate approve <csr_name> - $ oc adm certificate approve <csr_name>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <csr_name>is the name of a CSR from the list of current CSRs.
 
- If all the CSRs are valid, approve them all by running the following command: - oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- $ oc get csr -ojson | jq -r '.items[] | select(.status == {} ) | .metadata.name' | xargs oc adm certificate approve- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
4.1.14. Initial Operator configuration
After the control plane initializes, you must immediately configure some Operators so that they all become available.
Prerequisites
- Your control plane has initialized.
Procedure
- Watch the cluster components come online: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Configure the Operators that are not available.
4.1.14.1. Image registry storage configuration
						If the image-registry Operator is not available, you must configure storage for it. Instructions for both configuring a PersistentVolume, which is required for production clusters, and for configuring an empty directory as the storage location, which is available for only non-production clusters, are shown.
					
4.1.14.1.1. Configuring registry storage for VMware vSphere
As a cluster administrator, following installation you must configure your registry to use storage.
Prerequisites
- Cluster administrator permissions.
- A cluster on VMware vSphere.
- A provisioned persistent volume (PV) with - ReadWriteManyaccess mode, such as- NFS.Important- vSphere volumes do not support the - ReadWriteManyaccess mode. You must use a different storage backend, such as- NFS, to configure the registry storage.
- Must have "100Gi" capacity.
Procedure
- 
									To configure your registry to use storage, change the spec.storage.pvcin theconfigs.imageregistry/clusterresource.
- Verify you do not have a registry pod: - oc get pod -n openshift-image-registry - $ oc get pod -n openshift-image-registry- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
								If the storage type is emptyDIR, the replica number can not be greater than 1. If the storage type is NFS, and you want to scale up the registry Pod by setting replica>1 you must enable the no_wdelay mount option. For example:
							
cat /etc/exports /mnt/data *(rw,sync,no_wdelay,no_root_squash,insecure,fsid=0) sh-4.3# exportfs -rv exporting *:/mnt/data
# cat /etc/exports
/mnt/data *(rw,sync,no_wdelay,no_root_squash,insecure,fsid=0)
sh-4.3# exportfs -rv
exporting *:/mnt/data- Check the registry configuration: - oc edit configs.imageregistry.operator.openshift.io - $ oc edit configs.imageregistry.operator.openshift.io storage: pvc: claim:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Leave the - claimfield blank to allow the automatic creation of an- image-registry-storagePVC.
- Check the - clusteroperatorstatus:- oc get clusteroperator image-registry - $ oc get clusteroperator image-registry- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
4.1.14.1.2. Configuring storage for the image registry in non-production clusters
You must configure storage for the image registry Operator. For non-production clusters, you can set the image registry to an empty directory. If you do so, all images are lost if you restart the registry.
Procedure
- To set the image registry storage to an empty directory: - oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- $ oc patch configs.imageregistry.operator.openshift.io cluster --type merge --patch '{"spec":{"storage":{"emptyDir":{}}}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow Warning- Configure this option for only non-production clusters. - If you run this command before the Image Registry Operator initializes its components, the - oc patchcommand fails with the following error:- Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found - Error from server (NotFound): configs.imageregistry.operator.openshift.io "cluster" not found- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Wait a few minutes and run the command again. 
4.1.15. Completing installation on user-provisioned infrastructure
After you complete the Operator configuration, you can finish installing the cluster on infrastructure that you provide.
Prerequisites
- Your control plane has initialized.
- You have completed the initial Operator configuration.
Procedure
- Confirm that all the cluster components are online: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - When all of the cluster Operators are - AVAILABLE, you can complete the installation.
- Monitor for cluster completion: - ./openshift-install --dir=<installation_directory> wait-for install-complete - $ ./openshift-install --dir=<installation_directory> wait-for install-complete- 1 - INFO Waiting up to 30m0s for the cluster to initialize...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- For<installation_directory>, specify the path to the directory that you stored the installation files in.
 - The command succeeds when the Cluster Version Operator finishes deploying the OpenShift Container Platform cluster from Kubernetes API server. Important- The Ignition config files that the installation program generates contain certificates that expire after 24 hours. You must keep the cluster running for 24 hours in a non-degraded state to ensure that the first certificate rotation has finished. 
- Confirm that the Kubernetes API server is communicating with the Pods. - To view a list of all Pods, use the following command: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- View the logs for a Pod that is listed in the output of the previous command by using the following command: - oc logs <pod_name> -n <namespace> - $ oc logs <pod_name> -n <namespace>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specify the Pod name and namespace, as shown in the output of the previous command.
 - If the Pod logs display, the Kubernetes API server can communicate with the cluster machines. 
 
Next steps
- Customize your cluster.
- If necessary, you can opt out of telemetry.
Chapter 5. Gathering installation logs
To assist in troubleshooting a failed OpenShift Container Platform installation, you can gather logs from the bootstrap and control plane, or master, machines.
Prerequisites
- You attempted to install an OpenShift Container Platform cluster, and installation failed.
- 
					You provided an SSH key to the installation program, and that key is in your running ssh-agentprocess.
5.1. Gathering logs from a failed installation
If you gave an SSH key to your installation program, you can gather data about your failed installation.
					You use a different command to gather logs about an unsuccessful installation than to gather logs from a running cluster. If you must gather logs from a running cluster, use the oc adm must-gather command.
				
Prerequisites
- Your OpenShift Container Platform installation failed before the bootstrap process finished. The bootstrap node must be running and accessible through SSH.
- 
						The ssh-agentprocess is active on your computer, and you provided both thessh-agentprocess and the installation program the same SSH key.
- If you tried to install a cluster on infrastructure that you provisioned, you must have the fully-qualified domain names of the control plane, or master, machines.
Procedure
- Generate the commands that are required to obtain the installation logs from the bootstrap and control plane machines: - If you used installer-provisioned infrastructure, run the following command: - ./openshift-install gather bootstrap --dir=<directory> - $ ./openshift-install gather bootstrap --dir=<directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- installation_directoryis the directory you stored the OpenShift Container Platform definition files that the installation program creates.
 - For installer-provisioned infrastructure, the installation program stores information about the cluster, so you do not specify the host names or IP addresses 
- If you used infrastructure that you provisioned yourself, run the following command: - ./openshift-install gather bootstrap --dir=<directory> \ --bootstrap <bootstrap_address> \ --master "<master_address> <master_address> <master_address>"- $ ./openshift-install gather bootstrap --dir=<directory> \- 1 - --bootstrap <bootstrap_address> \- 2 - --master "<master_address> <master_address> <master_address>"- 3 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- installation_directoryis the directory you stored the OpenShift Container Platform definition files that the installation program creates.
- 2
- <bootstrap_address>is the fully-qualified domain name or IP address of the cluster’s bootstrap machine.
- 3
- <master_address>is the fully-qualified domain name or IP address of a control plane, or master, machine in your cluster. Specify a space-delimited list that contains all the control plane machines in your cluster.
 
 - The command output resembles the following example: - INFO Use the following commands to gather logs from the cluster INFO ssh -A core@<bootstrap_address> '/usr/local/bin/installer-gather.sh <master_address> <master_address> <master_address>' INFO scp core@<bootstrap_address>:~/log-bundle.tar.gz . - INFO Use the following commands to gather logs from the cluster INFO ssh -A core@<bootstrap_address> '/usr/local/bin/installer-gather.sh <master_address> <master_address> <master_address>' INFO scp core@<bootstrap_address>:~/log-bundle.tar.gz .- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You use both commands that are displayed to gather and download the logs. 
- Gather logs from the bootstrap and master machines: - ssh -A core@<bootstrap_address> '/usr/local/bin/installer-gather.sh <master_address> <master_address> <master_address>' - $ ssh -A core@<bootstrap_address> '/usr/local/bin/installer-gather.sh <master_address> <master_address> <master_address>'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - You SSH into the bootstrap machine and run the gather tool, which is designed to collect as much data as possible from the bootstrap and control plane machines in your cluster and compress all of the gathered files. Note- It is normal to see errors in the command output. If the command output displays the instructions to download the compressed log files, - log-bundle.tar.gz, then the command succeeded.
- Download the compressed file that contains the logs: - scp core@<bootstrap_address>:~/log-bundle.tar.gz . - $ scp core@<bootstrap_address>:~/log-bundle.tar.gz .- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- <bootstrap_address>is the fully-qualified domain name or IP address of the bootstrap machine.
 - The command to download the log files is included at the end of the gather command output. - If you open a Red Hat support case about your installation failure, include the compressed logs in the case. 
5.2. Manually gathering logs with SSH access to your host(s)
				Manually gather logs in situations where must-gather or automated collection methods do not work.
			
Prerequisites
- You must have SSH access to your host(s).
Procedure
- Collect the - bootkube.serviceservice logs from the bootstrap host using the- journalctlcommand by running:- journalctl -b -f -u bootkube.service - $ journalctl -b -f -u bootkube.service- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Collect the bootstrap host’s container logs using the Podman logs. This is shown as a loop to get all of the container logs from the host: - for pod in $(sudo podman ps -a -q); do sudo podman logs $pod; done - $ for pod in $(sudo podman ps -a -q); do sudo podman logs $pod; done- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Alternatively, collect the host’s container logs using the - tailcommand by running:- tail -f /var/lib/containers/storage/overlay-containers/*/userdata/ctr.log - # tail -f /var/lib/containers/storage/overlay-containers/*/userdata/ctr.log- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Collect the - kubelet.serviceand- crio.serviceservice logs from the master and worker hosts using the- journalctlcommand by running:- journalctl -b -f -u kubelet.service -u crio.service - $ journalctl -b -f -u kubelet.service -u crio.service- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Collect the master and worker host container logs using the - tailcommand by running:- sudo tail -f /var/log/containers/* - $ sudo tail -f /var/log/containers/*- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
5.3. Manually gathering logs without SSH access to your host(s)
				Manually gather logs in situations where must-gather or automated collection methods do not work.
			
If you do not have SSH access to your node, you can access the systems journal to investigate what is happening on your host.
Prerequisites
- Your OpenShift Container Platform installation must be complete.
- Your API service is still functional.
- You have system administrator privileges.
Procedure
- Access - journaldunit logs under- /var/logby running:- oc adm node-logs --role=master -u kubelet - $ oc adm node-logs --role=master -u kubelet- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Access host file paths under - /var/logby running:- oc adm node-logs --role=master --path=openshift-apiserver - $ oc adm node-logs --role=master --path=openshift-apiserver- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Chapter 6. Installation configuration
6.1. Available cluster customizations
You complete most of the cluster configuration and customization after you deploy your OpenShift Container Platform cluster. A number of configuration resources are available.
You modify the configuration resources to configure the major features of the cluster, such as the image registry, networking configuration, image build behavior, and the identity provider.
				For current documentation of settings these resources expose, use the oc explain command, for example oc explain builds --api-version=config.openshift.io/v1
			
6.1.1. Cluster configuration resources
					All cluster configuration resources are globally scoped (not namespaced) and named cluster.
				
| Resource name | Description | 
|---|---|
| apiserver.config.openshift.io | Provides api-server configuration such as certificates and certificate authorities. | 
| authentication.config.openshift.io | Controls the identity providerand authentication configuration for the cluster. | 
| build.config.openshift.io | Controls default and enforced configuration for all builds on the cluster. | 
| console.config.openshift.io | Configures the behavior of the web console interface, including the logout behavior. | 
| featuregate.config.openshift.io | Enables FeatureGates so that you can use Tech Preview features. | 
| image.config.openshift.io | Configures how specific image registries should be treated (allowed, disallowed, insecure, CA details). | 
| ingress.config.openshift.io | Configuration details related to routing such as the default domain for routes. | 
| oauth.config.openshift.io | Configures identity providers and other behavior related to internal OAuth server flows. | 
| project.config.openshift.io | Configures how projects are created including the project template. | 
| proxy.config.openshift.io | Defines proxies to be used by components needing external network access. Note: not all components currently consume this value. | 
| scheduler.config.openshift.io | Configures scheduler behavior such as policies and default nodeselectors. | 
6.1.2. Operator configuration resources
					These configuration resources are cluster-scoped instances, named cluster, which control the behavior of a specific component as owned by a particular operator.
				
| Resource name | Description | 
|---|---|
| console.operator.openshift.io | Controls console appearance such as branding customizations | 
| config.imageregistry.operator.openshift.io | Configures internal image registry settings such as public routing, log levels, proxy settings, resource constraints, replica counts, and storage type. | 
| config.samples.operator.openshift.io | Configures the Samples Operator to control which example imagestreams and templates are installed on the cluster. | 
6.1.3. Additional configuration resources
These configuration resources represent a single instance of a particular component, in some cases multiple instances can be requested by creating multiple instances of the resource. In other cases only a specific resource instance name in a specific namespace will be consumed by the operator. Reference the component-specific documentation for details on how and when additional resource instances can be created.
| Resource name | Instance name | Namespace | Description | 
|---|---|---|---|
| alertmanager.monitoring.coreos.com | main | openshift-monitoring | Controls the alertmanager deployment parameters. | 
| ingresscontroller.operator.openshift.io | default | openshift-ingress-operator | Configures Ingress Operator behavior such as domain, number of replicas, certificates, and controller placement. | 
6.1.4. Informational Resources
You use these resources to retrieve information about the cluster. You should not edit these resources directly.
| Resource name | Instance name | Description | 
|---|---|---|
| clusterversion.config.openshift.io | version | In OpenShift Container Platform 4.1, you must not customize the ClusterVersion resource for production clusters. Instead, follow the process to update a cluster. | 
| dns.config.openshift.io | cluster | You cannot modify the DNS settings for your cluster. You can view the DNS Operator status. | 
| infrastructure.config.openshift.io | cluster | Configuration details allowing the cluster to interact with its cloud provider. | 
| network.config.openshift.io | cluster | You cannot modify your cluster networking after installation. To customize your network, follow the process to customize networking during installation. | 
6.2. Configuring your firewall
If you use a firewall, you must configure it so that OpenShift Container Platform can access Red Hat Insights. This access is required for OpenShift Container Platform to access the Telemetry service, which is required to receive updates.
6.2.1. Configuring your firewall for OpenShift Container Platform
Before you install OpenShift Container Platform, you must configure your firewall to access Red Hat Insights.
Procedure
- Set your firewall to allow the following host names and ports on the outgoing network firewall: - cert-api.access.redhat.com:443 api.access.redhat.com:443 infogw.api.openshift.com:443 - cert-api.access.redhat.com:443 api.access.redhat.com:443 infogw.api.openshift.com:443- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
        Legal Notice
        
          
            
          
        
      
 
Copyright © 2025 Red Hat
OpenShift documentation is licensed under the Apache License 2.0 (https://www.apache.org/licenses/LICENSE-2.0).
Modified versions must remove all Red Hat trademarks.
Portions adapted from https://github.com/kubernetes-incubator/service-catalog/ with modifications by Red Hat.
Red Hat, Red Hat Enterprise Linux, the Red Hat logo, the Shadowman logo, JBoss, OpenShift, Fedora, the Infinity logo, and RHCE are trademarks of Red Hat, Inc., registered in the United States and other countries.
Linux® is the registered trademark of Linus Torvalds in the United States and other countries.
Java® is a registered trademark of Oracle and/or its affiliates.
XFS® is a trademark of Silicon Graphics International Corp. or its subsidiaries in the United States and/or other countries.
MySQL® is a registered trademark of MySQL AB in the United States, the European Union and other countries.
Node.js® is an official trademark of Joyent. Red Hat Software Collections is not formally related to or endorsed by the official Joyent Node.js open source or commercial project.
The OpenStack® Word Mark and OpenStack logo are either registered trademarks/service marks or trademarks/service marks of the OpenStack Foundation, in the United States and other countries and are used with the OpenStack Foundation’s permission. We are not affiliated with, endorsed or sponsored by the OpenStack Foundation, or the OpenStack community.
All other trademarks are the property of their respective owners.