Deploy a Local Openshift Cluster ¶
Demo Use Only
The instructions in this document are for testing and learning, and not intended for use in production.
Licensing
Openshift is a licensed product following the open source model where "upstream" versions are available under community licensing, but the official release supported by Red Hat requires a subscription in order to access the software for installation. This guide assumes the user has access to such a license. Red Hat provides a free Developer account that allows a participant to obtain a 60-day license of the Openshift product at no charge.
Video Demonstration
A video demonstration of the process outlined on this page is available here.
Some customers are using Openshift as their platform for running Ping containerized applications. If this is the case, access to an Openshift cluster is assumed. Even in those cases, there are times where a local implementation of Openshift for development and testing is convenient.
Platform
For this guide, the Apple MacBook Pro platform is used, and the release of the Red Hat Openshift Local offering is version 2.45.0, which installs Openshift 4.17.7.
The Openshift Local offering is used in this guide.
Prerequisites ¶
- Entitlement for Openshift code. If you have registered for the Red Hat developer program, you can obtain your entitlement for the free trial from the portal after logging in.
- kubectl
- Openshift client (oc)
- ports 80, 443 and 6443 available on machine. If you have Docker Desktop installed, you must either disable Kubernetes or stop Docker in order for the installation to work.
- sudo privileges on your hosting environment
Configuration and Setup ¶
-
Install the Red Hat Openshift Local binary for your platform. When you download the installer, also download the pull secret.
-
With the
crc
utility installed, configure settings. Provide as much RAM and CPU as you can, depending on your system. In this example, 16 GB of RAM, 7 vCPUs, and a disk size of 80GB are set. The consent-telemetry is optional, depending on whether you consent to usage data metrics being sent to Red Hat.# Version information crc version # Output CRC version: 2.45.0+7aeb3b OpenShift version: 4.17.7 MicroShift version: 4.17.7 # Set configuration crc config set memory 16384 crc config set cpus 7 crc config set consent-telemetry no crc config set disk-size 80 crc config set pull-secret-file <path>/pull-secret.txt # Confirm crc config view - consent-telemetry : no - cpus : 7 - disk-size : 80 - memory : 16384 - pull-secret-file : <path>/pull-secret.txt
-
Set up your local machine for running Red Hat Openshift Local by running crc setup:
crc setup # Output INFO Using bundle path /Users/davidross/.crc/cache/crc_vfkit_4.17.7_amd64.crcbundle INFO Checking if running macOS version >= 13.x INFO Checking if running as non-root INFO Checking if crc-admin-helper executable is cached INFO Checking if running on a supported CPU architecture INFO Checking if crc executable symlink exists INFO Checking minimum RAM requirements INFO Check if Podman binary exists in: /Users/davidross/.crc/bin/oc INFO Checking if running emulated on Apple silicon INFO Checking if vfkit is installed INFO Checking if CRC bundle is extracted in '$HOME/.crc' INFO Checking if /Users/davidross/.crc/cache/crc_vfkit_4.17.7_amd64.crcbundle exists INFO Getting bundle for the CRC executable INFO Downloading bundle: /Users/davidross/.crc/cache/crc_vfkit_4.17.7_amd64.crcbundle... 5.17 GiB / 5.17 GiB [---------------------------------------------------------------------------------] 100.00% 44.75 MiB/s INFO Uncompressing /Users/davidross/.crc/cache/crc_vfkit_4.17.7_amd64.crcbundle crc.img: 31.00 GiB / 31.00 GiB [---------------------------------------------------------------------------------] 100.00% oc: 128.23 MiB / 128.23 MiB [------------------------------------------------------------------------------------] 100.00% INFO Checking if old launchd config for tray and/or daemon exists INFO Checking if crc daemon plist file is present and loaded INFO Adding crc daemon plist file and loading it INFO Checking SSH port availability Your system is correctly setup for using CRC. Use 'crc start' to start the instance
-
Start the Red Hat Openshift Local instance:
crc start # Output INFO Using bundle path /Users/davidross/.crc/cache/crc_vfkit_4.17.7_amd64.crcbundle INFO Checking if running macOS version >= 13.x INFO Checking if running as non-root INFO Checking if crc-admin-helper executable is cached INFO Checking if running on a supported CPU architecture INFO Checking if crc executable symlink exists INFO Checking minimum RAM requirements INFO Check if Podman binary exists in: /Users/davidross/.crc/bin/oc INFO Checking if running emulated on Apple silicon INFO Checking if vfkit is installed INFO Checking if old launchd config for tray and/or daemon exists INFO Checking if crc daemon plist file is present and loaded INFO Checking SSH port availability INFO Loading bundle: crc_vfkit_4.17.7_amd64... INFO Creating CRC VM for OpenShift 4.17.7... INFO Generating new SSH key pair... INFO Generating new password for the kubeadmin user INFO Starting CRC VM for openshift 4.17.7... INFO CRC instance is running with IP 127.0.0.1 INFO CRC VM is running INFO Updating authorized keys... INFO Resizing /dev/vda4 filesystem INFO Configuring shared directories INFO Check internal and public DNS query... INFO Check DNS query from host... INFO Verifying validity of the kubelet certificates... INFO Starting kubelet service INFO Waiting for kube-apiserver availability... [takes around 2min] INFO Adding user's pull secret to the cluster... INFO Updating SSH key to machine config resource... INFO Waiting until the user's pull secret is written to the instance disk... INFO Changing the password for the kubeadmin user INFO Updating cluster ID... INFO Updating root CA cert to admin-kubeconfig-client-ca configmap... INFO Starting openshift instance... [waiting for the cluster to stabilize] INFO 2 operators are progressing: image-registry, ingress INFO Operator console is progressing INFO Operator console is progressing INFO All operators are available. Ensuring stability... INFO Operators are stable (2/3)... INFO Operators are stable (3/3)... INFO Adding crc-admin and crc-developer contexts to kubeconfig... Started the OpenShift cluster. The server is accessible via web console at: https://console-openshift-console.apps-crc.testing Log in as administrator: Username: kubeadmin Password: <password> Log in as user: Username: developer Password: <password> Use the 'oc' command line interface: $ eval $(crc oc-env) $ oc login -u developer https://api.crc.testing:6443
Depending on the speed of your system, this will take 8 to 15 minutes. There is a 10 minute timeout on checking the stability of operators deployed by Openshift. It might be the case that the tool reports these have not reached full stability in that window. In the writing of this guide, no issues were found using Openshift deployed in this manner, even if the error occurs. Each time the steps in this guide were tested, everything eventually reached a healthy status, even if not in the window expected on some occasions.
Setup is complete. This local environment should be ready to deploy our Helm examples
Stop the Red Hat Openshift Local instance ¶
When not working with the environment, you can stop the instance by running the following command. All settings, projects and objects created will be retained and available when it is started again.
crc stop
Run crc start
again to launch the instance.
Delete the Red Hat Openshift Local instance ¶
You can also remove the instance by running the following command. If you do this, the embedded VM instance, all objects and projects created will be lost. A new instance will be deployed the next time you run crc start
.
crc delete
Remove all configuration
Deleting the instance does not delete the configuration settings for Red Hat Openshift Local (RAM, CPU, disk, and so on, created or modified when running the crc config set
command). If you want to completely remove all configuration, you can delete the $HOME/.crc folder and its contents. Also, you will need to edit /etc/hosts
and remove the following aliases to the 127.0.0.1 IP: api.crc.testing canary-openshift-ingress-canary.apps-crc.testing console-openshift-console.apps-crc.testing default-route-openshift-image-registry.apps-crc.testing downloads-openshift-console.apps-crc.testing oauth-openshift.apps-crc.testing