Chapter 20. AWS Load Balancer Operator
20.1. AWS Load Balancer Operator release notes
				The AWS Load Balancer (ALB) Operator deploys and manages an instance of the AWSLoadBalancerController resource.
			
					The AWS Load Balancer (ALB) Operator is only supported on the x86_64 architecture.
				
These release notes track the development of the AWS Load Balancer Operator in OpenShift Container Platform.
For an overview of the AWS Load Balancer Operator, see AWS Load Balancer Operator in OpenShift Container Platform.
AWS Load Balancer Operator currently does not support AWS GovCloud.
20.1.1. AWS Load Balancer Operator 1.0.0
The AWS Load Balancer Operator is now generally available with this release. The AWS Load Balancer Operator version 1.0.0 supports the AWS Load Balancer Controller version 2.4.4.
The following advisory is available for the AWS Load Balancer Operator version 1.0.0:
20.1.1.1. Notable changes
- 
								This release uses the new v1API version.
20.1.1.2. Bug fixes
- Previously, the controller provisioned by the AWS Load Balancer Operator did not properly use the configuration for the cluster-wide proxy. These settings are now applied appropriately to the controller. (OCPBUGS-4052, OCPBUGS-5295)
20.1.2. Earlier versions
The two earliest versions of the AWS Load Balancer Operator are available as a Technology Preview. These versions should not be used in a production cluster. For more information about the support scope of Red Hat Technology Preview features, see Technology Preview Features Support Scope.
The following advisory is available for the AWS Load Balancer Operator version 0.2.0:
The following advisory is available for the AWS Load Balancer Operator version 0.0.1:
20.2. AWS Load Balancer Operator in OpenShift Container Platform
The AWS Load Balancer Operator deploys and manages the AWS Load Balancer Controller. You can install the AWS Load Balancer Operator from OperatorHub by using OpenShift Container Platform web console or CLI.
20.2.1. AWS Load Balancer Operator considerations
Review the following limitations before installing and using the AWS Load Balancer Operator:
- The IP traffic mode only works on AWS Elastic Kubernetes Service (EKS). The AWS Load Balancer Operator disables the IP traffic mode for the AWS Load Balancer Controller. As a result of disabling the IP traffic mode, the AWS Load Balancer Controller cannot use the pod readiness gate.
- 
							The AWS Load Balancer Operator adds command-line flags such as --disable-ingress-class-annotationand--disable-ingress-group-name-annotationto the AWS Load Balancer Controller. Therefore, the AWS Load Balancer Operator does not allow using thekubernetes.io/ingress.classandalb.ingress.kubernetes.io/group.nameannotations in theIngressresource.
- 
							You have configured the AWS Load Balancer Operator so that the SVC type is NodePort(notLoadBalancerorClusterIP).
20.2.2. AWS Load Balancer Operator
					The AWS Load Balancer Operator can tag the public subnets if the kubernetes.io/role/elb tag is missing. Also, the AWS Load Balancer Operator detects the following information from the underlying AWS cloud:
				
- The ID of the virtual private cloud (VPC) on which the cluster hosting the Operator is deployed in.
- Public and private subnets of the discovered VPC.
					The AWS Load Balancer Operator supports the Kubernetes service resource of type LoadBalancer by using Network Load Balancer (NLB) with the instance target type only.
				
Prerequisites
- You must have the AWS credentials secret. The credentials are used to provide subnet tagging and VPC discovery.
Procedure
- You can deploy the AWS Load Balancer Operator on demand from OperatorHub, by creating a - Subscriptionobject by running the following command:- oc -n aws-load-balancer-operator get sub aws-load-balancer-operator --template='{{.status.installplan.name}}{{"\n"}}'- $ oc -n aws-load-balancer-operator get sub aws-load-balancer-operator --template='{{.status.installplan.name}}{{"\n"}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - install-zlfbt - install-zlfbt- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check if the status of an install plan is - Completeby running the following command:- oc -n aws-load-balancer-operator get ip <install_plan_name> --template='{{.status.phase}}{{"\n"}}'- $ oc -n aws-load-balancer-operator get ip <install_plan_name> --template='{{.status.phase}}{{"\n"}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - Complete - Complete- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- View the status of the - aws-load-balancer-operator-controller-managerdeployment by running the following command:- oc get -n aws-load-balancer-operator deployment/aws-load-balancer-operator-controller-manager - $ oc get -n aws-load-balancer-operator deployment/aws-load-balancer-operator-controller-manager- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - NAME READY UP-TO-DATE AVAILABLE AGE aws-load-balancer-operator-controller-manager 1/1 1 1 23h - NAME READY UP-TO-DATE AVAILABLE AGE aws-load-balancer-operator-controller-manager 1/1 1 1 23h- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.2.3. AWS Load Balancer Operator logs
					You can view the AWS Load Balancer Operator logs by using the oc logs command.
				
Procedure
- View the logs of the AWS Load Balancer Operator by running the following command: - oc logs -n aws-load-balancer-operator deployment/aws-load-balancer-operator-controller-manager -c manager - $ oc logs -n aws-load-balancer-operator deployment/aws-load-balancer-operator-controller-manager -c manager- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.3. Installing the AWS Load Balancer Operator
The AWS Load Balancer Operator deploys and manages the AWS Load Balancer Controller. You can install the AWS Load Balancer Operator from the OperatorHub by using OpenShift Container Platform web console or CLI.
20.3.1. Installing the AWS Load Balancer Operator by using the web console
You can install the AWS Load Balancer Operator by using the web console.
Prerequisites
- 
							You have logged in to the OpenShift Container Platform web console as a user with cluster-adminpermissions.
- Your cluster is configured with AWS as the platform type and cloud provider.
- If you are using a security token service (STS) or user-provisioned infrastructure, follow the related preparation steps. For example, if you are using AWS Security Token Service, see "Preparing for the AWS Load Balancer Operator on a cluster using the AWS Security Token Service (STS)".
Procedure
- 
							Navigate to Operators OperatorHub in the OpenShift Container Platform web console. 
- Select the AWS Load Balancer Operator. You can use the Filter by keyword text box or use the filter list to search for the AWS Load Balancer Operator from the list of Operators.
- 
							Select the aws-load-balancer-operatornamespace.
- On the Install Operator page, select the following options: - Update the channel as stable-v1.
- Installation mode as All namespaces on the cluster (default).
- 
									Installed Namespace as aws-load-balancer-operator. If theaws-load-balancer-operatornamespace does not exist, it gets created during the Operator installation.
- Select Update approval as Automatic or Manual. By default, the Update approval is set to Automatic. If you select automatic updates, the Operator Lifecycle Manager (OLM) automatically upgrades the running instance of your Operator without any intervention. If you select manual updates, the OLM creates an update request. As a cluster administrator, you must then manually approve that update request to update the Operator updated to the new version.
 
- Click Install.
Verification
- Verify that the AWS Load Balancer Operator shows the Status as Succeeded on the Installed Operators dashboard.
20.3.2. Installing the AWS Load Balancer Operator by using the CLI
You can install the AWS Load Balancer Operator by using the CLI.
Prerequisites
- 
							You are logged in to the OpenShift Container Platform web console as a user with cluster-adminpermissions.
- Your cluster is configured with AWS as the platform type and cloud provider.
- 
							You are logged into the OpenShift CLI (oc).
Procedure
- Create a - Namespaceobject:- Create a YAML file that defines the - Namespaceobject:- Example - namespace.yamlfile- apiVersion: v1 kind: Namespace metadata: name: aws-load-balancer-operator - apiVersion: v1 kind: Namespace metadata: name: aws-load-balancer-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - Namespaceobject by running the following command:- oc apply -f namespace.yaml - $ oc apply -f namespace.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a - CredentialsRequestobject:- Create a YAML file that defines the - CredentialsRequestobject:- Example - credentialsrequest.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - CredentialsRequestobject by running the following command:- oc apply -f credentialsrequest.yaml - $ oc apply -f credentialsrequest.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create an - OperatorGroupobject:- Create a YAML file that defines the - OperatorGroupobject:- Example - operatorgroup.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - OperatorGroupobject by running the following command:- oc apply -f operatorgroup.yaml - $ oc apply -f operatorgroup.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
- Create a - Subscriptionobject:- Create a YAML file that defines the - Subscriptionobject:- Example - subscription.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - Subscriptionobject by running the following command:- oc apply -f subscription.yaml - $ oc apply -f subscription.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
 
Verification
- Get the name of the install plan from the subscription: - oc -n aws-load-balancer-operator \ get subscription aws-load-balancer-operator \ --template='{{.status.installplan.name}}{{"\n"}}'- $ oc -n aws-load-balancer-operator \ get subscription aws-load-balancer-operator \ --template='{{.status.installplan.name}}{{"\n"}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Check the status of the install plan: - oc -n aws-load-balancer-operator \ get ip <install_plan_name> \ --template='{{.status.phase}}{{"\n"}}'- $ oc -n aws-load-balancer-operator \ get ip <install_plan_name> \ --template='{{.status.phase}}{{"\n"}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - The output must be - Complete.
20.4. Preparing for the AWS Load Balancer Operator on a cluster using the AWS Security Token Service
You can install the AWS Load Balancer Operator on a cluster that uses STS. Follow these steps to prepare your cluster before installing the Operator.
				The AWS Load Balancer Operator relies on the CredentialsRequest object to bootstrap the Operator and the AWS Load Balancer Controller. The AWS Load Balancer Operator waits until the required secrets are created and available. The Cloud Credential Operator does not provision the secrets automatically in the STS cluster. You must set the credentials secrets manually by using the ccoctl binary.
			
				If you do not want to provision credential secret by using the Cloud Credential Operator, you can configure the AWSLoadBalancerController instance on the STS cluster by specifying the credential secret in the AWS load Balancer Controller custom resource (CR).
			
20.4.1. Bootstrapping AWS Load Balancer Operator on Security Token Service cluster
Prerequisites
- 
							You must extract and prepare the ccoctlbinary.
Procedure
- Create the - aws-load-balancer-operatornamespace by running the following command:- oc create namespace aws-load-balancer-operator - $ oc create namespace aws-load-balancer-operator- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Download the - CredentialsRequestcustom resource (CR) of the AWS Load Balancer Operator, and create a directory to store it by running the following command:- curl --create-dirs -o <path-to-credrequests-dir>/cr.yaml https://raw.githubusercontent.com/openshift/aws-load-balancer-operator/main/hack/operator-credentials-request.yaml - $ curl --create-dirs -o <path-to-credrequests-dir>/cr.yaml https://raw.githubusercontent.com/openshift/aws-load-balancer-operator/main/hack/operator-credentials-request.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the - ccoctltool to process- CredentialsRequestobjects of the AWS Load Balancer Operator, by running the following command:- ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- $ ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the secrets generated in the manifests directory of your cluster by running the following command: - ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- $ ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the credentials secret of the AWS Load Balancer Operator is created by running the following command: - oc -n aws-load-balancer-operator get secret aws-load-balancer-operator --template='{{index .data "credentials"}}' | base64 -d- $ oc -n aws-load-balancer-operator get secret aws-load-balancer-operator --template='{{index .data "credentials"}}' | base64 -d- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - [default] sts_regional_endpoints = regional role_arn = arn:aws:iam::999999999999:role/aws-load-balancer-operator-aws-load-balancer-operator web_identity_token_file = /var/run/secrets/openshift/serviceaccount/token - [default] sts_regional_endpoints = regional role_arn = arn:aws:iam::999999999999:role/aws-load-balancer-operator-aws-load-balancer-operator web_identity_token_file = /var/run/secrets/openshift/serviceaccount/token- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.4.2. Configuring AWS Load Balancer Operator on Security Token Service cluster by using managed CredentialsRequest objects
Prerequisites
- 
							You must extract and prepare the ccoctlbinary.
Procedure
- The AWS Load Balancer Operator creates the - CredentialsRequestobject in the- openshift-cloud-credential-operatornamespace for each- AWSLoadBalancerControllercustom resource (CR). You can extract and save the created- CredentialsRequestobject in a directory by running the following command:- oc get credentialsrequest -n openshift-cloud-credential-operator \ aws-load-balancer-controller-<cr-name> -o yaml > <path-to-credrequests-dir>/cr.yaml- $ oc get credentialsrequest -n openshift-cloud-credential-operator \ aws-load-balancer-controller-<cr-name> -o yaml > <path-to-credrequests-dir>/cr.yaml- 1 - Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Theaws-load-balancer-controller-<cr-name>parameter specifies the credential request name created by the AWS Load Balancer Operator. Thecr-namespecifies the name of the AWS Load Balancer Controller instance.
 
- Use the - ccoctltool to process all- CredentialsRequestobjects in the- credrequestsdirectory by running the following command:- ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- $ ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the secrets generated in manifests directory to your cluster, by running the following command: - ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- $ ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify that the - aws-load-balancer-controllerpod is created:- oc -n aws-load-balancer-operator get pods - $ oc -n aws-load-balancer-operator get pods NAME READY STATUS RESTARTS AGE aws-load-balancer-controller-cluster-9b766d6-gg82c 1/1 Running 0 137m aws-load-balancer-operator-controller-manager-b55ff68cc-85jzg 2/2 Running 0 3h26m- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.4.3. Configuring the AWS Load Balancer Operator on Security Token Service cluster by using specific credentials
					You can specify the credential secret by using the spec.credentials field in the AWS Load Balancer Controller custom resource (CR). You can use the predefined CredentialsRequest object of the controller to know which roles are required.
				
Prerequisites
- 
							You must extract and prepare the ccoctlbinary.
Procedure
- Download the CredentialsRequest custom resource (CR) of the AWS Load Balancer Controller, and create a directory to store it by running the following command: - curl --create-dirs -o <path-to-credrequests-dir>/cr.yaml https://raw.githubusercontent.com/openshift/aws-load-balancer-operator/main/hack/controller/controller-credentials-request.yaml - $ curl --create-dirs -o <path-to-credrequests-dir>/cr.yaml https://raw.githubusercontent.com/openshift/aws-load-balancer-operator/main/hack/controller/controller-credentials-request.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Use the - ccoctltool to process the- CredentialsRequestobject of the controller:- ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- $ ccoctl aws create-iam-roles \ --name <name> --region=<aws_region> \ --credentials-requests-dir=<path-to-credrequests-dir> \ --identity-provider-arn <oidc-arn>- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Apply the secrets to your cluster: - ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- $ ls manifests/*-credentials.yaml | xargs -I{} oc apply -f {}- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify the credentials secret has been created for use by the controller: - oc -n aws-load-balancer-operator get secret aws-load-balancer-controller-manual-cluster --template='{{index .data "credentials"}}' | base64 -d- $ oc -n aws-load-balancer-operator get secret aws-load-balancer-controller-manual-cluster --template='{{index .data "credentials"}}' | base64 -d- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - [default] sts_regional_endpoints = regional role_arn = arn:aws:iam::999999999999:role/aws-load-balancer-operator-aws-load-balancer-controller web_identity_token_file = /var/run/secrets/openshift/serviceaccount/token- [default] sts_regional_endpoints = regional role_arn = arn:aws:iam::999999999999:role/aws-load-balancer-operator-aws-load-balancer-controller web_identity_token_file = /var/run/secrets/openshift/serviceaccount/token- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - AWSLoadBalancerControllerresource YAML file, for example,- sample-aws-lb-manual-creds.yaml, as follows:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.5. Creating an instance of the AWS Load Balancer Controller
After installing the AWS Load Balancer Operator, you can create the AWS Load Balancer Controller.
20.5.1. Creating the AWS Load Balancer Controller
					You can install only a single instance of the AWSLoadBalancerController object in a cluster. You can create the AWS Load Balancer Controller by using CLI. The AWS Load Balancer Operator reconciles only the cluster named resource.
				
Prerequisites
- 
							You have created the echoservernamespace.
- 
							You have access to the OpenShift CLI (oc).
Procedure
- Create a YAML file that defines the - AWSLoadBalancerControllerobject:- Example - sample-aws-lb.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Defines theAWSLoadBalancerControllerobject.
- 2
- Defines the AWS Load Balancer Controller name. This instance name gets added as a suffix to all related resources.
- 3
- Configures the subnet tagging method for the AWS Load Balancer Controller. The following values are valid:- 
											Auto: The AWS Load Balancer Operator determines the subnets that belong to the cluster and tags them appropriately. The Operator cannot determine the role correctly if the internal subnet tags are not present on internal subnet.
- 
											Manual: You manually tag the subnets that belong to the cluster with the appropriate role tags. Use this option if you installed your cluster on user-provided infrastructure.
 
- 
											
- 4
- Defines the tags used by the AWS Load Balancer Controller when it provisions AWS resources.
- 5
- Defines the ingress class name. The default value isalb.
- 6
- Specifies the number of replicas of the AWS Load Balancer Controller.
- 7
- Specifies annotations as an add-on for the AWS Load Balancer Controller.
- 8
- Enables thealb.ingress.kubernetes.io/wafv2-acl-arnannotation.
 
- Create the - AWSLoadBalancerControllerobject by running the following command:- oc create -f sample-aws-lb.yaml - $ oc create -f sample-aws-lb.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a YAML file that defines the - Deploymentresource:- Example - sample-aws-lb.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a YAML file that defines the - Serviceresource:- Example - service-albo.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create a YAML file that defines the - Ingressresource:- Example - ingress-albo.yamlfile:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
Verification
- Save the status of the - Ingressresource in the- HOSTvariable by running the following command:- HOST=$(oc get ingress -n echoserver echoserver --template='{{(index .status.loadBalancer.ingress 0).hostname}}')- $ HOST=$(oc get ingress -n echoserver echoserver --template='{{(index .status.loadBalancer.ingress 0).hostname}}')- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Verify the status of the - Ingressresource by running the following command:- curl $HOST - $ curl $HOST- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.6. Serving multiple ingress resources through a single AWS Load Balancer
You can route the traffic to different services that are part of a single domain through a single AWS Load Balancer. Each Ingress resource provides different endpoints of the domain.
20.6.1. Creating multiple ingress resources through a single AWS Load Balancer
You can route the traffic to multiple ingress resources through a single AWS Load Balancer by using the CLI.
Prerequisites
- 
							You have an access to the OpenShift CLI (oc).
Procedure
- Create an - IngressClassParamsresource YAML file, for example,- sample-single-lb-params.yaml, as follows:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - IngressClassParamsresource by running the following command:- oc create -f sample-single-lb-params.yaml - $ oc create -f sample-single-lb-params.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - IngressClassresource YAML file, for example,- sample-single-lb-class.yaml, as follows:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Defines the API group and version of theIngressClassresource.
- 2
- Specifies the ingress class name.
- 3
- Defines the controller name. Theingress.k8s.aws/albvalue denotes that all ingress resources of this class should be managed by the AWS Load Balancer Controller.
- 4
- Defines the API group of theIngressClassParamsresource.
- 5
- Defines the resource type of theIngressClassParamsresource.
- 6
- Defines theIngressClassParamsresource name.
 
- Create the - IngressClassresource by running the following command:- oc create -f sample-single-lb-class.yaml - $ oc create -f sample-single-lb-class.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - AWSLoadBalancerControllerresource YAML file, for example,- sample-single-lb.yaml, as follows:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Defines the name of theIngressClassresource.
 
- Create the - AWSLoadBalancerControllerresource by running the following command:- oc create -f sample-single-lb.yaml - $ oc create -f sample-single-lb.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Create the - Ingressresource YAML file, for example,- sample-multiple-ingress.yaml, as follows:- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specifies the ingress name.
- 2
- Indicates the load balancer to provision in the public subnet to access the internet.
- 3
- Specifies the order in which the rules from the multiple ingress resources are matched when the request is received at the load balancer.
- 4
- Indicates that the load balancer will target OpenShift Container Platform nodes to reach the service.
- 5
- Specifies the ingress class that belongs to this ingress.
- 6
- Defines a domain name used for request routing.
- 7
- Defines the path that must route to the service.
- 8
- Defines the service name that serves the endpoint configured in theIngressresource.
- 9
- Defines the port on the service that serves the endpoint.
 
- Create the - Ingressresource by running the following command:- oc create -f sample-multiple-ingress.yaml - $ oc create -f sample-multiple-ingress.yaml- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
20.7. Adding TLS termination
You can add TLS termination on the AWS Load Balancer.
20.7.1. Adding TLS termination on the AWS Load Balancer
You can route the traffic for the domain to pods of a service and add TLS termination on the AWS Load Balancer.
Prerequisites
- 
							You have an access to the OpenShift CLI (oc).
Procedure
- Create a YAML file that defines the - AWSLoadBalancerControllerresource:- Example - add-tls-termination-albc.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Defines the ingress class name. If the ingress class is not present in your cluster the AWS Load Balancer Controller creates one. The AWS Load Balancer Controller reconciles the additional ingress class values ifspec.controlleris set toingress.k8s.aws/alb.
 
- Create a YAML file that defines the - Ingressresource:- Example - add-tls-termination-ingress.yamlfile- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - 1
- Specifies the ingress name.
- 2
- The controller provisions the load balancer for ingress in a public subnet to access the load balancer over the internet.
- 3
- The Amazon Resource Name (ARN) of the certificate that you attach to the load balancer.
- 4
- Defines the ingress class name.
- 5
- Defines the domain for traffic routing.
- 6
- Defines the service for traffic routing.
 
20.8. Configuring cluster-wide proxy
				You can configure the cluster-wide proxy in the AWS Load Balancer Operator. After configuring the cluster-wide proxy, Operator Lifecycle Manager (OLM) automatically updates all the deployments of the Operators with the environment variables such as HTTP_PROXY, HTTPS_PROXY, and NO_PROXY. These variables are populated to the managed controller by the AWS Load Balancer Operator.
			
20.8.1. Trusting the certificate authority of the cluster-wide proxy
- Create the config map to contain the certificate authority (CA) bundle in the - aws-load-balancer-operatornamespace by running the following command:- oc -n aws-load-balancer-operator create configmap trusted-ca - $ oc -n aws-load-balancer-operator create configmap trusted-ca- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- To inject the trusted CA bundle into the config map, add the - config.openshift.io/inject-trusted-cabundle=truelabel to the config map by running the following command:- oc -n aws-load-balancer-operator label cm trusted-ca config.openshift.io/inject-trusted-cabundle=true - $ oc -n aws-load-balancer-operator label cm trusted-ca config.openshift.io/inject-trusted-cabundle=true- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Update the AWS Load Balancer Operator subscription to access the config map in the AWS Load Balancer Operator deployment by running the following command: - oc -n aws-load-balancer-operator patch subscription aws-load-balancer-operator --type='merge' -p '{"spec":{"config":{"env":[{"name":"TRUSTED_CA_CONFIGMAP_NAME","value":"trusted-ca"}],"volumes":[{"name":"trusted-ca","configMap":{"name":"trusted-ca"}}],"volumeMounts":[{"name":"trusted-ca","mountPath":"/etc/pki/tls/certs/albo-tls-ca-bundle.crt","subPath":"ca-bundle.crt"}]}}}'- $ oc -n aws-load-balancer-operator patch subscription aws-load-balancer-operator --type='merge' -p '{"spec":{"config":{"env":[{"name":"TRUSTED_CA_CONFIGMAP_NAME","value":"trusted-ca"}],"volumes":[{"name":"trusted-ca","configMap":{"name":"trusted-ca"}}],"volumeMounts":[{"name":"trusted-ca","mountPath":"/etc/pki/tls/certs/albo-tls-ca-bundle.crt","subPath":"ca-bundle.crt"}]}}}'- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- After the AWS Load Balancer Operator is deployed, verify that the CA bundle is added to the - aws-load-balancer-operator-controller-managerdeployment by running the following command:- oc -n aws-load-balancer-operator exec deploy/aws-load-balancer-operator-controller-manager -c manager -- bash -c "ls -l /etc/pki/tls/certs/albo-tls-ca-bundle.crt; printenv TRUSTED_CA_CONFIGMAP_NAME" - $ oc -n aws-load-balancer-operator exec deploy/aws-load-balancer-operator-controller-manager -c manager -- bash -c "ls -l /etc/pki/tls/certs/albo-tls-ca-bundle.crt; printenv TRUSTED_CA_CONFIGMAP_NAME"- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow - Example output - -rw-r--r--. 1 root 1000690000 5875 Jan 11 12:25 /etc/pki/tls/certs/albo-tls-ca-bundle.crt trusted-ca - -rw-r--r--. 1 root 1000690000 5875 Jan 11 12:25 /etc/pki/tls/certs/albo-tls-ca-bundle.crt trusted-ca- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow 
- Optional: Restart deployment of the AWS Load Balancer Operator every time the config map changes by running the following command: - oc -n aws-load-balancer-operator rollout restart deployment/aws-load-balancer-operator-controller-manager - $ oc -n aws-load-balancer-operator rollout restart deployment/aws-load-balancer-operator-controller-manager- Copy to Clipboard Copied! - Toggle word wrap Toggle overflow