Validation and troubleshooting
Validating and troubleshooting an OpenShift Container Platform installation
Abstract
Chapter 1. Validating an installation
You can check the status of an OpenShift Container Platform cluster after an installation or validate boot artifacts before an installation by following the procedures in this document.
1.1. Validating RHCOS live media
				The OpenShift Container Platform installation program contains pinned versions of RHCOS bootimages. Fully automated installations use these pinned artifacts by default. The mirror registry where you downloaded the installation program contains a sha256sum encrypted with the Red Hat product key.
			
For user-provisioned infrastructure installations, you can access information and use the OpenShift Container Platform installer to indirectly validate RHCOS bootimage artifacts using their SHA-256 checksums.
Procedure
- Run the following command to print the metadata for any bootimage artifact: - openshift-install coreos print-stream-json | jq <bootimage> - $ openshift-install coreos print-stream-json | jq <bootimage>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- The query for the bootimage you want to obtain information on. For validation purposes, the bootimage artifact must have a generatedsha256sum. This can include OVA, VHD, QCOW2 and others. For example, to get information on anx86_64architectureisofile for bare metal platforms, this value would be.architectures.x86_64.artifacts.metal.formats.iso.
 - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
/validating-an-installation.adoc
1.2. Reviewing the installation log
You can review a summary of an installation in the OpenShift Container Platform installation log. If an installation succeeds, the information required to access the cluster is included in the log.
Prerequisites
- You have access to the installation host.
Procedure
- Review the - .openshift_install.loglog file in the installation directory on your installation host:- cat <install_dir>/.openshift_install.log - $ cat <install_dir>/.openshift_install.log- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Cluster credentials are included at the end of the log if the installation is successful, as outlined in the following example: - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
1.3. Viewing the image pull source
				For clusters with unrestricted network connectivity, you can view the source of your pulled images by using a command on a node, such as crictl images.
			
				However, for disconnected installations, to view the source of pulled images, you must review the CRI-O logs to locate the Trying to access log entry, as shown in the following procedure. Other methods to view the image pull source, such as the crictl images command, show the non-mirrored image name, even though the image is pulled from the mirrored location.
			
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
Procedure
- Review the CRI-O logs for a master or worker node: - oc adm node-logs <node_name> -u crio - $ oc adm node-logs <node_name> -u crio- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - The - Trying to accesslog entry indicates where the image is being pulled from.- ... Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1366]: time="2021-08-05 10:33:21.594930907Z" level=info msg="Pulling image: quay.io/openshift-release-dev/ocp-release:4.10.0-ppc64le" id=abcd713b-d0e1-4844-ac1c-474c5b60c07c name=/runtime.v1alpha2.ImageService/PullImage Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1484]: time="2021-03-17 02:52:50.194341109Z" level=info msg="Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\"" Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1484]: time="2021-03-17 02:52:50.226788351Z" level=info msg="Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\"" ... - ... Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1366]: time="2021-08-05 10:33:21.594930907Z" level=info msg="Pulling image: quay.io/openshift-release-dev/ocp-release:4.10.0-ppc64le" id=abcd713b-d0e1-4844-ac1c-474c5b60c07c name=/runtime.v1alpha2.ImageService/PullImage Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1484]: time="2021-03-17 02:52:50.194341109Z" level=info msg="Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\"" Mar 17 02:52:50 ip-10-0-138-140.ec2.internal crio[1484]: time="2021-03-17 02:52:50.226788351Z" level=info msg="Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\"" ...- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The log might show the image pull source twice, as shown in the preceding example. - If your - ImageContentSourcePolicyobject lists multiple mirrors, OpenShift Container Platform attempts to pull the images in the order listed in the configuration, for example:- Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\" Trying to access \"li0317gcp2.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\" - Trying to access \"li0317gcp1.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\" Trying to access \"li0317gcp2.mirror-registry.qe.gcp.devcluster.openshift.com:5000/ocp/release@sha256:1926eae7cacb9c00f142ec98b00628970e974284b6ddaf9a6a086cb9af7a6c31\"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
/validating-an-installation.adoc
1.4. Getting cluster version, status, and update details
				You can view the cluster version and status by running the oc get clusterversion command. If the status shows that the installation is still progressing, you can review the status of the Operators for more information.
			
You can also list the current update channel and review the available cluster updates.
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
- 
						You have installed the OpenShift CLI (oc).
Procedure
- Obtain the cluster version and overall status: - oc get clusterversion - $ oc get clusterversion- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME VERSION AVAILABLE PROGRESSING SINCE STATUS version 4.6.4 True False 6m25s Cluster version is 4.6.4 - NAME VERSION AVAILABLE PROGRESSING SINCE STATUS version 4.6.4 True False 6m25s Cluster version is 4.6.4- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The example output indicates that the cluster has been installed successfully. 
- If the cluster status indicates that the installation is still progressing, you can obtain more detailed progress information by checking the status of the Operators: - oc get clusteroperators.config.openshift.io - $ oc get clusteroperators.config.openshift.io- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- View a detailed summary of cluster specifications, update availability, and update history: - oc describe clusterversion - $ oc describe clusterversion- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- List the current update channel: - oc get clusterversion -o jsonpath='{.items[0].spec}{"\n"}'- $ oc get clusterversion -o jsonpath='{.items[0].spec}{"\n"}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - {"channel":"stable-4.6","clusterID":"245539c1-72a3-41aa-9cec-72ed8cf25c5c"}- {"channel":"stable-4.6","clusterID":"245539c1-72a3-41aa-9cec-72ed8cf25c5c"}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Review the available cluster updates: - oc adm upgrade - $ oc adm upgrade- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
/validating-an-installation.adoc
1.5. Verifying that a cluster uses short-term credentials
You can verify that a cluster uses short-term security credentials for individual components by checking the Cloud Credential Operator (CCO) configuration and other values in the cluster.
Prerequisites
- 
						You deployed an OpenShift Container Platform cluster using the Cloud Credential Operator utility (ccoctl) to implement short-term credentials.
- 
						You installed the OpenShift CLI (oc).
- 
						You are logged in as a user with cluster-adminprivileges.
Procedure
- Verify that the CCO is configured to operate in manual mode by running the following command: - oc get cloudcredentials cluster \ -o=jsonpath={.spec.credentialsMode}- $ oc get cloudcredentials cluster \ -o=jsonpath={.spec.credentialsMode}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The following output confirms that the CCO is operating in manual mode: - Example output - Manual - Manual- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the cluster does not have - rootcredentials by running the following command:- oc get secrets \ -n kube-system <secret_name> - $ oc get secrets \ -n kube-system <secret_name>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - where - <secret_name>is the name of the root secret for your cloud provider.- Expand - Platform - Secret name - Amazon Web Services (AWS) - aws-creds- Microsoft Azure - azure-credentials- Google Cloud - gcp-credentials- An error confirms that the root secret is not present on the cluster. - Example output for an AWS cluster - Error from server (NotFound): secrets "aws-creds" not found - Error from server (NotFound): secrets "aws-creds" not found- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the components are using short-term security credentials for individual components by running the following command: - oc get authentication cluster \ -o jsonpath \ --template='{ .spec.serviceAccountIssuer }'- $ oc get authentication cluster \ -o jsonpath \ --template='{ .spec.serviceAccountIssuer }'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - This command displays the value of the - .spec.serviceAccountIssuerparameter in the cluster- Authenticationobject. An output of a URL that is associated with your cloud provider indicates that the cluster is using manual mode with short-term credentials that are created and managed from outside of the cluster.
- Azure clusters: Verify that the components are assuming the Azure client ID that is specified in the secret manifests by running the following command: - oc get secrets \ -n openshift-image-registry installer-cloud-credentials \ -o jsonpath='{.data}'- $ oc get secrets \ -n openshift-image-registry installer-cloud-credentials \ -o jsonpath='{.data}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - An output that contains the - azure_client_idand- azure_federated_token_filefelids confirms that the components are assuming the Azure client ID.
- Azure clusters: Verify that the pod identity webhook is running by running the following command: - oc get pods \ -n openshift-cloud-credential-operator - $ oc get pods \ -n openshift-cloud-credential-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY STATUS RESTARTS AGE cloud-credential-operator-59cf744f78-r8pbq 2/2 Running 2 71m pod-identity-webhook-548f977b4c-859lz 1/1 Running 1 70m - NAME READY STATUS RESTARTS AGE cloud-credential-operator-59cf744f78-r8pbq 2/2 Running 2 71m pod-identity-webhook-548f977b4c-859lz 1/1 Running 1 70m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
/validating-an-installation.adoc
1.6. Querying the status of the cluster nodes by using the CLI
You can verify the status of the cluster nodes after an installation.
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
- 
						You have installed the OpenShift CLI (oc).
Procedure
- List the status of the cluster nodes. Verify that the output lists all of the expected control plane and compute nodes and that each node has a - Readystatus:- oc get nodes - $ oc get nodes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Review CPU and memory resource availability for each cluster node: - oc adm top nodes - $ oc adm top nodes- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
/validating-an-installation.adoc
1.7. Reviewing the cluster status from the OpenShift Container Platform web console
You can review the following information in the Overview page in the OpenShift Container Platform web console:
- The general status of your cluster
- The status of the control plane, cluster Operators, and storage
- CPU, memory, file system, network transfer, and pod availability
- The API address of the cluster, the cluster ID, and the name of the provider
- Cluster version information
- Cluster update status, including details of the current update channel and available updates
- A cluster inventory detailing node, pod, storage class, and persistent volume claim (PVC) information
- A list of ongoing cluster activities and recent events
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
Procedure
- In the Administrator perspective, navigate to Home → Overview.
/validating-an-installation.adoc
1.8. Reviewing the cluster status from Red Hat OpenShift Cluster Manager
From the OpenShift Container Platform web console, you can review detailed information about the status of your cluster on OpenShift Cluster Manager.
Prerequisites
- You are logged in to OpenShift Cluster Manager.
- 
						You have access to the cluster as a user with the cluster-adminrole.
Procedure
- Go to the Clusters list in OpenShift Cluster Manager and locate your OpenShift Container Platform cluster.
- Click the Overview tab for your cluster.
- Review the following information about your cluster: - vCPU and memory availability and resource usage
- The cluster ID, status, type, region, and the provider name
- Node counts by node type
- Cluster version details, the creation date of the cluster, and the name of the cluster owner
- The life cycle support status of the cluster
- Subscription information, including the service level agreement (SLA) status, the subscription unit type, the production status of the cluster, the subscription obligation, and the service level Tip- To view the history for your cluster, click the Cluster history tab. 
 
- Navigate to the Monitoring page to review the following information: - A list of any issues that have been detected
- A list of alerts that are firing
- The cluster Operator status and version
- The cluster’s resource usage
 
- Optional: You can view information about your cluster that Red Hat Insights collects by navigating to the Overview menu. From this menu you can view the following information: - Potential issues that your cluster might be exposed to, categorized by risk level
- Health-check status by category
 
/validating-an-installation.adoc
1.9. Checking cluster resource availability and utilization
OpenShift Container Platform provides a comprehensive set of monitoring dashboards that help you understand the state of cluster components.
In the Administrator perspective, you can access dashboards for core OpenShift Container Platform components, including:
- etcd
- Kubernetes compute resources
- Kubernetes network resources
- Prometheus
- Dashboards relating to cluster and node performance
Figure 1.1. Example compute resources dashboard
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
Procedure
- In the Administrator perspective in the OpenShift Container Platform web console, navigate to Observe → Dashboards.
- Choose a dashboard in the Dashboard list. Some dashboards, such as the etcd dashboard, produce additional sub-menus when selected.
- Optional: Select a time range for the graphs in the Time Range list. - Select a pre-defined time period.
- Set a custom time range by selecting Custom time range in the Time Range list. - Input or select the From and To dates and times.
- Click Save to save the custom time range.
 
 
- Optional: Select a Refresh Interval.
- Hover over each of the graphs within a dashboard to display detailed information about specific items.
/validating-an-installation.adoc
1.10. Listing alerts that are firing
Alerts provide notifications when a set of defined conditions are true in an OpenShift Container Platform cluster. You can review the alerts that are firing in your cluster by using the Alerting UI in the OpenShift Container Platform web console.
Prerequisites
- 
						You have access to the cluster as a user with the cluster-adminrole.
Procedure
- In the Administrator perspective, navigate to the Observe → Alerting → Alerts page.
- Review the alerts that are firing, including their Severity, State, and Source.
- Select an alert to view more detailed information in the Alert Details page.
1.11. Next steps
- See Troubleshooting installations if you experience issues when installing your cluster.
- After installing OpenShift Container Platform, you can further expand and customize your cluster.
Chapter 2. Troubleshooting installation issues
To assist in troubleshooting a failed OpenShift Container Platform installation, you can gather logs from the bootstrap and control plane machines. You can also get debug information from the installation program. If you are unable to resolve the issue using the logs and debug information, see Determining where installation issues occur for component-specific troubleshooting.
If your OpenShift Container Platform installation fails and the debug output or logs contain network timeouts or other connectivity errors, review the guidelines for configuring your firewall. Gathering logs from your firewall and load balancer can help you diagnose network-related errors.
2.1. Prerequisites
- You attempted to install an OpenShift Container Platform cluster and the installation failed.
2.2. 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 is running and accessible through SSH.
- 
						The ssh-agentprocess is active on your computer, and you provided the same SSH key to both thessh-agentprocess and the installation program.
- If you tried to install a cluster on infrastructure that you provisioned, you must have the fully qualified domain names of the bootstrap and control plane nodes.
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, change to the directory that contains the installation program and run the following command: - ./openshift-install gather bootstrap --dir <installation_directory> - $ ./openshift-install gather bootstrap --dir <installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- installation_directoryis the directory you specified when you ran- ./openshift-install create cluster. This directory contains 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 hostnames or IP addresses. 
- If you used infrastructure that you provisioned yourself, change to the directory that contains the installation program and run the following command: - ./openshift-install gather bootstrap --dir <installation_directory> \ --bootstrap <bootstrap_address> \ --master <master_1_address> \ --master <master_2_address> \ --master <master_3_address>- $ ./openshift-install gather bootstrap --dir <installation_directory> \- 1 - --bootstrap <bootstrap_address> \- 2 - --master <master_1_address> \- 3 - --master <master_2_address> \- 4 - --master <master_3_address>- 5 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Forinstallation_directory, specify the same directory you specified when you ran./openshift-install create cluster. This directory contains 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 4 5
- For each control plane, or master, machine in your cluster, replace<master_*_address>with its fully qualified domain name or IP address.
 Note- A default cluster contains three control plane machines. List all of your control plane machines as shown, no matter how many your cluster uses. 
 - Example output - INFO Pulling debug logs from the bootstrap machine INFO Bootstrap gather logs captured here "<installation_directory>/log-bundle-<timestamp>.tar.gz" - INFO Pulling debug logs from the bootstrap machine INFO Bootstrap gather logs captured here "<installation_directory>/log-bundle-<timestamp>.tar.gz"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - If you open a Red Hat support case about your installation failure, include the compressed logs in the case. 
2.3. 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.
			
By default, SSH access to the OpenShift Container Platform nodes is disabled on the Red Hat OpenStack Platform (RHOSP) based installations.
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 
2.4. 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 
2.5. Getting debug information from the installation program
You can use any of the following actions to get debug information from the installation program.
- Look at debug messages from a past installation in the hidden - .openshift_install.logfile. For example, enter:- cat ~/<installation_directory>/.openshift_install.log - $ cat ~/<installation_directory>/.openshift_install.log- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Forinstallation_directory, specify the same directory you specified when you ran./openshift-install create cluster.
 
- Change to the directory that contains the installation program and re-run it with - --log-level=debug:- ./openshift-install create cluster --dir <installation_directory> --log-level debug - $ ./openshift-install create cluster --dir <installation_directory> --log-level debug- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Forinstallation_directory, specify the same directory you specified when you ran./openshift-install create cluster.
 
2.6. Reinstalling the OpenShift Container Platform cluster
If you are unable to debug and resolve issues in the failed OpenShift Container Platform installation, consider installing a new OpenShift Container Platform cluster. Before starting the installation process again, you must complete thorough cleanup. For a user-provisioned infrastructure (UPI) installation, you must manually destroy the cluster and delete all associated resources. The following procedure is for an installer-provisioned infrastructure (IPI) installation.
Procedure
- Destroy the cluster and remove all the resources associated with the cluster, including the hidden installer state files in the installation directory: - ./openshift-install destroy cluster --dir <installation_directory> - $ ./openshift-install destroy cluster --dir <installation_directory>- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- installation_directoryis the directory you specified when you ran- ./openshift-install create cluster. This directory contains the OpenShift Container Platform definition files that the installation program creates.
 
- Before reinstalling the cluster, delete the installation directory: - rm -rf <installation_directory> - $ rm -rf <installation_directory>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Follow the procedure for installing a new OpenShift Container Platform cluster.
        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.
