Chapter 2. Comprehensive guide to getting started with Red Hat OpenShift Service on AWS classic architecture
If you are looking for a quickstart guide for ROSA, see Red Hat OpenShift Service on AWS classic architecture quickstart guide.
Follow this getting started document to create a Red Hat OpenShift Service on AWS classic architecture (ROSA) cluster, grant user access, deploy your first application, and learn how to revoke user access and delete your cluster.
You can create a ROSA cluster either with or without the AWS Security Token Service (STS). The procedures in this document enable you to create a cluster that uses AWS STS. For more information about using AWS STS with ROSA clusters, see Using the AWS Security Token Service.
2.1. Prerequisites Copy linkLink copied to clipboard!
- You reviewed the introduction to Red Hat OpenShift Service on AWS classic architecture (ROSA), and the documentation on ROSA architecture models and architecture concepts.
- You have read the documentation on the guidelines for planning your environment.
- You have reviewed the detailed AWS prerequisites for ROSA with STS.
- You have the AWS service quotas that are required to run a ROSA cluster.
2.2. Setting up the environment Copy linkLink copied to clipboard!
Before you create a Red Hat OpenShift Service on AWS classic architecture cluster, you must set up your environment by completing the following tasks:
- Verify Red Hat OpenShift Service on AWS classic architecture prerequisites against your AWS and Red Hat accounts.
- Install and configure the required command-line interface (CLI) tools.
- Verify the configuration of the CLI tools.
You can follow the procedures in this section to complete these setup requirements.
2.2.1. Verifying Red Hat OpenShift Service on AWS classic architecture prerequisites Copy linkLink copied to clipboard!
Use the steps in this procedure to enable Red Hat OpenShift Service on AWS classic architecture in your AWS account.
Prerequisites
- You have a Red Hat account.
You have an AWS account.
NoteConsider using a dedicated AWS account to run production clusters. If you are using AWS Organizations, you can use an AWS account within your organization or create a new one.
Procedure
- Sign in to the AWS Management Console.
- Navigate to the ROSA service.
Click Get started.
The Verify ROSA prerequisites page opens.
Under ROSA enablement, ensure that a green check mark and
You previously enabled ROSAare displayed.If not, follow these steps:
-
Select the checkbox beside
I agree to share my contact information with Red Hat. Click Enable ROSA.
After a short wait, a green check mark and
You enabled ROSAmessage are displayed.
-
Select the checkbox beside
Under Service Quotas, ensure that a green check and
Your quotas meet the requirements for ROSAare displayed.If you see
Your quotas don’t meet the minimum requirements, take note of the quota type and the minimum listed in the error message. See Amazon’s documentation on requesting a quota increase for guidance. It may take several hours for Amazon to approve your quota request.-
Under ELB service-linked role, ensure that a green check mark and
AWSServiceRoleForElasticLoadBalancing already existsare displayed. Click Continue to Red Hat.
The Get started with Red Hat OpenShift Service on AWS classic architecture (ROSA) page opens in a new tab. You have already completed Step 1 on this page, and can now continue with Step 2.
2.2.2. Installing and configuring the required CLI tools Copy linkLink copied to clipboard!
Several command-line interface (CLI) tools are required to deploy and work with your cluster.
Prerequisites
- You have an AWS account.
- You have a Red Hat account.
Procedure
Log in to your Red Hat and AWS accounts to access the download page for each required tool.
- Log in to your Red Hat account at console.redhat.com.
- Log in to your AWS account at aws.amazon.com.
Install and configure the latest AWS CLI (
aws).- Install the AWS CLI by following the AWS Command Line Interface documentation appropriate for your workstation.
Configure the AWS CLI by specifying your
aws_access_key_id,aws_secret_access_key, andregionin the.aws/credentialsfile. For more information, see AWS Configuration basics in the AWS documentation.NoteYou can optionally use the
AWS_DEFAULT_REGIONenvironment variable to set the default AWS region.Query the AWS API to verify if the AWS CLI is installed and configured correctly:
$ aws sts get-caller-identity --output textFor example:
<aws_account_id> arn:aws:iam::<aws_account_id>:user/<username> <aws_user_id>
Install and configure the latest ROSA CLI.
- Navigate to Downloads.
Find Red Hat OpenShift Service on AWS command line interface (
rosa) in the list of tools and click Download.The
rosa-linux.tar.gzfile is downloaded to your default download location.Extract the
rosabinary file from the downloaded archive. The following example extracts the binary from a Linux tar archive:$ tar xvf rosa-linux.tar.gzMove the
rosabinary file to a directory in your execution path. In the following example, the/usr/local/bindirectory is included in the path of the user:$ sudo mv rosa /usr/local/bin/rosaVerify that the ROSA CLI is installed correctly by querying the
rosaversion:$ rosa versionFor example:
1.2.47 Your ROSA CLI is up to date.
Log in to the ROSA CLI using an offline access token.
Run the login command:
$ rosa loginFor example:
To login to your Red Hat account, get an offline access token at https://console.redhat.com/openshift/token/rosa ? Copy the token and paste it here:- Navigate to the URL listed in the command output to view your offline access token.
Enter the offline access token at the command-line prompt to log in.
? Copy the token and paste it here: ******************* [full token length omitted]NoteIn the future you can specify the offline access token by using the
--token="<offline_access_token>"argument when you run therosa logincommand.Verify that you are logged in and confirm that your credentials are correct before proceeding:
$ rosa whoamiFor example:
AWS Account ID: <aws_account_number> AWS Default Region: us-east-1 AWS ARN: arn:aws:iam::<aws_account_number>:user/<aws_user_name> OCM API: https://api.openshift.com OCM Account ID: <red_hat_account_id> OCM Account Name: Your Name OCM Account Username: you@domain.com OCM Account Email: you@domain.com OCM Organization ID: <org_id> OCM Organization Name: Your organization OCM Organization External ID: <external_org_id>
Install and configure the latest OpenShift CLI (
oc).Use the ROSA CLI to download the
ocCLI.The following command downloads the latest version of the CLI to the current working directory:
$ rosa download openshift-clientExtract the
ocbinary file from the downloaded archive. The following example extracts the files from a Linux tar archive:$ tar xvf openshift-client-linux.tar.gzMove the
ocbinary to a directory in your execution path. In the following example, the/usr/local/bindirectory is included in the path of the user:$ sudo mv oc /usr/local/bin/ocVerify that the
ocCLI is installed correctly:$ rosa verify openshift-clientFor example:
I: Verifying whether OpenShift command-line tool is available... I: Current OpenShift Client Version: 4.17.3
2.3. Creating a ROSA cluster with STS Copy linkLink copied to clipboard!
Choose from one of the following methods to deploy a Red Hat OpenShift Service on AWS classic architecture (ROSA) cluster that uses the AWS Security Token Service (STS). In each scenario, you can deploy your cluster by using Red Hat OpenShift Cluster Manager or the ROSA CLI (rosa):
- Creating a ROSA cluster with STS using the default options: You can create a ROSA cluster with STS quickly by using the default options and automatic STS resource creation.
-
Creating a ROSA cluster with STS using customizations: You can create a ROSA cluster with STS using customizations. You can also choose between the
autoandmanualmodes when creating the required STS resources.
2.4. Creating a cluster administrator user for quick cluster access Copy linkLink copied to clipboard!
Before configuring an identity provider, you can create a user with cluster-admin privileges for immediate access to your Red Hat OpenShift Service on AWS classic architecture (ROSA) cluster.
The cluster administrator user is useful when you need quick access to a newly deployed cluster. However, consider configuring an identity provider and granting cluster administrator privileges to the identity provider users as required. For more information about setting up an identity provider for your ROSA cluster, see Configuring an identity provider and granting cluster access.
Prerequisites
- You have an AWS account.
-
You installed and configured the latest Red Hat OpenShift Service on AWS classic architecture (ROSA) CLI,
rosa, on your workstation. -
You logged in to your Red Hat account using the ROSA CLI (
rosa). - You created a ROSA cluster.
Procedure
Create a cluster administrator user:
$ rosa create admin --cluster=<cluster_name>1 - 1
- Replace
<cluster_name>with the name of your cluster.
Example output
W: It is recommended to add an identity provider to login to this cluster. See 'rosa create idp --help' for more information. I: Admin account has been added to cluster '<cluster_name>'. I: Please securely store this generated password. If you lose this password you can delete and recreate the cluster admin user. I: To login, run the following command: oc login https://api.example-cluster.wxyz.p1.openshiftapps.com:6443 --username cluster-admin --password d7Rca-Ba4jy-YeXhs-WU42J I: It may take up to a minute for the account to become active.NoteIt might take approximately one minute for the
cluster-adminuser to become active.Log in to the cluster through the CLI:
Run the command provided in the output of the preceding step to log in:
$ oc login <api_url> --username cluster-admin --password <cluster_admin_password>1 - 1
- Replace
<api_url>and<cluster_admin_password>with the API URL and cluster administrator password for your environment.
Verify if you are logged in to the ROSA cluster as the
cluster-adminuser:$ oc whoamiExample output
cluster-admin
Additional resource
- For steps to log in to the ROSA web console, see Accessing a cluster through the web console
2.5. Configuring an identity provider and granting cluster access Copy linkLink copied to clipboard!
Red Hat OpenShift Service on AWS classic architecture (ROSA) includes a built-in OAuth server. After your ROSA cluster is created, you must configure OAuth to use an identity provider. You can then add members to your configured identity provider to grant them access to your cluster.
You can also grant the identity provider users with cluster-admin or dedicated-admin privileges as required.
2.5.1. Configuring an identity provider Copy linkLink copied to clipboard!
You can configure different identity provider types for your Red Hat OpenShift Service on AWS classic architecture (ROSA) cluster. Supported types include GitHub, GitHub Enterprise, GitLab, Google, LDAP, OpenID Connect and htpasswd identity providers.
The htpasswd identity provider option is included only to enable the creation of a single, static administration user. htpasswd is not supported as a general-use identity provider for Red Hat OpenShift Service on AWS classic architecture.
The following procedure configures a GitHub identity provider as an example.
Prerequisites
- You have an AWS account.
-
You installed and configured the latest Red Hat OpenShift Service on AWS classic architecture (ROSA) CLI,
rosa, on your workstation. -
You logged in to your Red Hat account using the ROSA CLI (
rosa). - You created a ROSA cluster.
- You have a GitHub user account.
Procedure
- Go to github.com and log in to your GitHub account.
- If you do not have an existing GitHub organization to use for identity provisioning for your ROSA cluster, create one. Follow the steps in the GitHub documentation.
Configure a GitHub identity provider for your cluster that is restricted to the members of your GitHub organization.
Configure an identity provider using the interactive mode:
$ rosa create idp --cluster=<cluster_name> --interactive1 - 1
- Replace
<cluster_name>with the name of your cluster.
Example output
I: Interactive mode enabled. Any optional fields can be left empty and a default will be selected. ? Type of identity provider: github ? Identity provider name: github-1 ? Restrict to members of: organizations ? GitHub organizations: <github_org_name>1 ? To use GitHub as an identity provider, you must first register the application: - Open the following URL: https://github.com/organizations/<github_org_name>/settings/applications/new?oauth_application%5Bcallback_url%5D=https%3A%2F%2Foauth-openshift.apps.<cluster_name>/<random_string>.p1.openshiftapps.com%2Foauth2callback%2Fgithub-1&oauth_application%5Bname%5D=<cluster_name>&oauth_application%5Burl%5D=https%3A%2F%2Fconsole-openshift-console.apps.<cluster_name>/<random_string>.p1.openshiftapps.com - Click on 'Register application' ...- 1
- Replace
<github_org_name>with the name of your GitHub organization.
Follow the URL in the output and select Register application to register a new OAuth application in your GitHub organization. By registering the application, you enable the OAuth server that is built into ROSA to authenticate members of your GitHub organization into your cluster.
NoteThe fields in the Register a new OAuth application GitHub form are automatically filled with the required values through the URL defined by the ROSA CLI.
Use the information from your GitHub OAuth application page to populate the remaining
rosa create idpinteractive prompts.Continued example output
... ? Client ID: <github_client_id>1 ? Client Secret: [? for help] <github_client_secret>2 ? GitHub Enterprise Hostname (optional): ? Mapping method: claim3 I: Configuring IDP for cluster '<cluster_name>' I: Identity Provider 'github-1' has been created. It will take up to 1 minute for this configuration to be enabled. To add cluster administrators, see 'rosa grant user --help'. To login into the console, open https://console-openshift-console.apps.<cluster_name>.<random_string>.p1.openshiftapps.com and click on github-1.NoteIt might take approximately two minutes for the identity provider configuration to become active. If you have configured a
cluster-adminuser, you can watch the OAuth pods redeploy with the updated configuration by runningoc get pods -n openshift-authentication --watch.Enter the following command to verify that the identity provider has been configured correctly:
$ rosa list idps --cluster=<cluster_name>Example output
NAME TYPE AUTH URL github-1 GitHub https://oauth-openshift.apps.<cluster_name>.<random_string>.p1.openshiftapps.com/oauth2callback/github-1
Additional resource
- For detailed steps to configure each of the supported identity provider types, see Configuring identity providers for STS
2.5.2. Granting user access to a cluster Copy linkLink copied to clipboard!
You can grant a user access to your Red Hat OpenShift Service on AWS classic architecture cluster by adding them to your configured identity provider.
You can configure different types of identity providers for your Red Hat OpenShift Service on AWS classic architecture cluster. The following example procedure adds a user to a GitHub organization that is configured for identity provision to the cluster.
Prerequisites
- You have an AWS account.
- You installed and configured the latest ROSA CLI on your workstation.
- You logged in to your Red Hat account using the ROSA CLI.
- You created a Red Hat OpenShift Service on AWS classic architecture cluster.
- You have a GitHub user account.
- You have configured a GitHub identity provider for your cluster.
Procedure
- Navigate to github.com and log in to your GitHub account.
- Invite users that require access to the Red Hat OpenShift Service on AWS classic architecture cluster to your GitHub organization. Follow the steps in Inviting users to join your organization in the GitHub documentation.
2.5.3. Granting administrator privileges to a user Copy linkLink copied to clipboard!
After you have added a user to your configured identity provider, you can grant the user cluster-admin or dedicated-admin privileges for your Red Hat OpenShift Service on AWS classic architecture cluster.
Prerequisites
- You have an AWS account.
-
You installed and configured the latest ROSA CLI,
rosa, on your workstation. -
You logged in to your Red Hat account using the ROSA CLI (
rosa). - You created a Red Hat OpenShift Service on AWS classic architecture cluster.
- You have configured a GitHub identity provider for your cluster and added identity provider users.
Procedure
To configure
cluster-adminprivileges for an identity provider user:Grant the user
cluster-adminprivileges:$ rosa grant user cluster-admin --user=<idp_user_name> --cluster=<cluster_name>Example output
I: Granted role 'cluster-admins' to user '<idp_user_name>' on cluster '<cluster_name>'Verify if the user is listed as a member of the
cluster-adminsgroup:$ rosa list users --cluster=<cluster_name>Example output
ID GROUPS <idp_user_name> cluster-admins
To configure
dedicated-adminprivileges for an identity provider user:Grant the user
dedicated-adminprivileges:$ rosa grant user dedicated-admin --user=<idp_user_name> --cluster=<cluster_name>Example output
I: Granted role 'dedicated-admins' to user '<idp_user_name>' on cluster '<cluster_name>'Verify if the user is listed as a member of the
dedicated-adminsgroup:$ rosa list users --cluster=<cluster_name>Example output
ID GROUPS <idp_user_name> dedicated-admins
2.6. Accessing a cluster through the web console Copy linkLink copied to clipboard!
After you have created a cluster administrator user or added a user to your configured identity provider, you can log into your Red Hat OpenShift Service on AWS classic architecture cluster through the web console.
Prerequisites
- You have an AWS account.
-
You installed and configured the latest ROSA CLI,
rosa, on your workstation. -
You logged in to your Red Hat account using the ROSA CLI (
rosa). - You created a Red Hat OpenShift Service on AWS classic architecture cluster.
- You have created a cluster administrator user or added your user account to the configured identity provider.
Procedure
Obtain the console URL for your cluster:
$ rosa describe cluster -c <cluster_name> | grep ConsoleExample output
Console URL: https://console-openshift-console.apps.example-cluster.wxyz.p1.openshiftapps.comGo to the console URL in the output of the preceding step and log in.
-
If you created a
cluster-adminuser, log in by using the provided credentials. - If you configured an identity provider for your cluster, select the identity provider name in the Log in with… dialog and complete any authorization requests that are presented by your provider.
-
If you created a
2.7. Deploying an application from the Developer Catalog Copy linkLink copied to clipboard!
From the Red Hat OpenShift Service on AWS classic architecture web console, you can deploy a test application from the Developer Catalog and expose it with a route.
Prerequisites
- You logged in to the Red Hat Hybrid Cloud Console.
- You created a Red Hat OpenShift Service on AWS classic architecture cluster.
- You configured an identity provider for your cluster.
- You added your user account to the configured identity provider.
Procedure
- Go to the Cluster List page in OpenShift Cluster Manager.
- Click the options icon (⋮) next to the cluster you want to view.
- Click Open console.
- Your cluster console opens in a new browser window. Log in to your Red Hat account with your configured identity provider credentials.
-
In the Administrator perspective, select Home
Projects Create Project. - Enter a name for your project and optionally add a Display Name and Description.
- Click Create to create the project.
- Switch to the Developer perspective and select +Add. Verify that the selected Project is the one that you just created.
- In the Developer Catalog dialog, select All services.
-
In the Developer Catalog page, select Languages
JavaScript from the menu. Click Node.js, and then click Create to open the Create Source-to-Image application page.
NoteYou might need to click Clear All Filters to display the Node.js option.
- In the Git section, click Try sample.
- Add a unique name in the Name field. The value will be used to name the associated resources.
- Confirm that Deployment and Create a route are selected.
- Click Create to deploy the application. It will take a few minutes for the pods to deploy.
-
Optional: Check the status of the pods in the Topology pane by selecting your Node.js app and reviewing its sidebar. You must wait for the
nodejsbuild to complete and for thenodejspod to be in a Running state before continuing. When the deployment is complete, click the route URL for the application, which has a format similar to the following:
https://nodejs-<project>.<cluster_name>.<hash>.<region>.openshiftapps.com/A new tab in your browser opens with a message similar to the following:
Welcome to your Node.js application on OpenShiftOptional: Delete the application and clean up the resources that you created:
-
In the Administrator perspective, navigate to Home
Projects. - Click the action menu for your project and select Delete Project.
-
In the Administrator perspective, navigate to Home
2.8. Revoking administrator privileges and user access Copy linkLink copied to clipboard!
You can revoke cluster-admin or dedicated-admin privileges from a user by using the ROSA CLI, rosa.
To revoke cluster access from a user, you must remove the user from your configured identity provider.
Follow the procedures in this section to revoke administrator privileges or cluster access from a user.
2.8.1. Revoking administrator privileges from a user Copy linkLink copied to clipboard!
Follow the steps in this section to revoke cluster-admin or dedicated-admin privileges from a user.
Prerequisites
-
You installed and configured the latest ROSA CLI,
rosa, on your workstation. -
You logged in to your Red Hat account using the ROSA CLI (
rosa). - You created a Red Hat OpenShift Service on AWS classic architecture cluster.
- You have configured a GitHub identity provider for your cluster and added an identity provider user.
-
You granted
cluster-adminordedicated-adminprivileges to a user.
Procedure
To revoke
cluster-adminprivileges from an identity provider user:Revoke the
cluster-adminprivilege:$ rosa revoke user cluster-admin --user=<idp_user_name> --cluster=<cluster_name>Example output
? Are you sure you want to revoke role cluster-admins from user <idp_user_name> in cluster <cluster_name>? Yes I: Revoked role 'cluster-admins' from user '<idp_user_name>' on cluster '<cluster_name>'Verify that the user is not listed as a member of the
cluster-adminsgroup:$ rosa list users --cluster=<cluster_name>Example output
W: There are no users configured for cluster '<cluster_name>'
To revoke
dedicated-adminprivileges from an identity provider user:Revoke the
dedicated-adminprivilege:$ rosa revoke user dedicated-admin --user=<idp_user_name> --cluster=<cluster_name>Example output
? Are you sure you want to revoke role dedicated-admins from user <idp_user_name> in cluster <cluster_name>? Yes I: Revoked role 'dedicated-admins' from user '<idp_user_name>' on cluster '<cluster_name>'Verify that the user is not listed as a member of the
dedicated-adminsgroup:$ rosa list users --cluster=<cluster_name>Example output
W: There are no users configured for cluster '<cluster_name>'
2.8.2. Revoking user access to a cluster Copy linkLink copied to clipboard!
You can revoke cluster access for an identity provider user by removing them from your configured identity provider.
You can configure different types of identity providers for your Red Hat OpenShift Service on AWS classic architecture cluster. The following example procedure revokes cluster access for a member of a GitHub organization that is configured for identity provision to the cluster.
Prerequisites
- You have a Red Hat OpenShift Service on AWS classic architecture cluster.
- You have a GitHub user account.
- You have configured a GitHub identity provider for your cluster and added an identity provider user.
Procedure
- Navigate to github.com and log in to your GitHub account.
- Remove the user from your GitHub organization. Follow the steps in Removing a member from your organization in the GitHub documentation.
2.9. Deleting a Red Hat OpenShift Service on AWS classic architecture cluster and the AWS IAM STS resources Copy linkLink copied to clipboard!
You can delete a Red Hat OpenShift Service on AWS classic architecture cluster that uses the AWS Security Token Service (STS) by using the ROSA CLI. You can also use the ROSA CLI to delete the AWS Identity and Access Management (IAM) account-wide roles, the cluster-specific Operator roles, and the OpenID Connect (OIDC) provider. To delete the account-wide inline and Operator policies, you can use the AWS IAM Console or the AWS CLI.
Account-wide IAM roles and policies might be used by other Red Hat OpenShift Service on AWS classic architecture clusters in the same AWS account. You must only remove the resources if they are not required by other clusters.
Prerequisites
- You installed and configured the latest ROSA CLI on your workstation.
- You logged in to your Red Hat account using the ROSA CLI.
- You created a Red Hat OpenShift Service on AWS classic architecture cluster.
Procedure
Delete a cluster and watch the logs, replacing
<cluster_name>with the name or ID of your cluster:$ rosa delete cluster --cluster=<cluster_name> --watchImportantYou must wait for the cluster deletion to complete before you remove the IAM roles, policies, and OIDC provider. The account-wide roles are required to delete the resources created by the installer. The cluster-specific Operator roles are required to clean-up the resources created by the OpenShift Operators. The Operators use the OIDC provider to authenticate with AWS APIs.
After the cluster is deleted, delete the OIDC provider that the cluster Operators use to authenticate:
$ rosa delete oidc-provider -c <cluster_id> --mode autoNoteYou can use the
-yoption to automatically answer yes to the prompts.Delete the cluster-specific Operator IAM roles:
$ rosa delete operator-roles -c <cluster_id> --mode autoDelete the account-wide roles:
ImportantAccount-wide IAM roles and policies might be used by other Red Hat OpenShift Service on AWS classic architecture clusters in the same AWS account. You must only remove the resources if they are not required by other clusters.
$ rosa delete account-roles --prefix <prefix> --mode autoReplace
<prefix>with the prefix of the account-wide roles to delete. If you did not specify a custom prefix when you created the account-wide roles, specify the default prefix, depending on how they were created,HCP-ROSAorManagedOpenShift.Delete the account-wide and Operator IAM policies that you created for Red Hat OpenShift Service on AWS classic architecture deployments that use STS:
- Log in to the AWS IAM Console.
-
Navigate to Access management
Policies and select the checkbox for one of the account-wide policies. -
With the policy selected, click on Actions
Delete to open the delete policy dialog. - Enter the policy name to confirm the deletion and select Delete to delete the policy.
- Repeat this step to delete each of the account-wide and Operator policies for the cluster.