All Products
Search
Document Center

Server Load Balancer:ALB Ingress user guide

Last Updated:Dec 11, 2024

In addition to Container Service for Kubernetes (ACK) and ACK Serverless, Application Load Balancer (ALB) Ingresses can be used together with Enterprise Distributed Application Service (EDAS), Serverless App Engine (SAE), and self-managed Kubernetes clusters in the cloud to meet your business requirements. This topic describes the basic and advanced features of ALB Ingresses and provides references on how to use ALB Ingresses together with other services.

Basic features

An AlbConfig is a custom resource definition (CRD) object of ACK that is used by the ALB Ingress controller to configure ALB instances and listeners. The following table describes how to install and uninstall the ALB Ingress controller in ACK and ACK Serverless clusters, create and modify AlbConfigs, and enable Simple Log Service.

Item

Feature

Description

References for ACK

References for ACK Serverless

ALB Ingress Controller

Manage the ALB Ingress controller

ACK provides managed ALB Ingress controllers.

You can install an ALB Ingress controller when you create a cluster or install the controller on the Components page after you create a cluster.

Manage the ALB Ingress controller

Manage the ALB Ingress controller

Instance management

Create an AlbConfig

An AlbConfig is a CRD object that is used by the ALB Ingress controller to configure ALB instances and listeners.

An AlbConfig is used to configure a single ALB instance. If you want to configure multiple ALB instances, you must create multiple AlbConfigs.

Create an AlbConfig

Create an AlbConfig

Associate an AlbConfig with an Ingress

You can associate an AlbConfig with an Ingress by using an IngressClass. To do this, you must first create an IngressClass.

Create and associate an IngressClass with an AlbConfig.

Use an IngressClass to associate an AlbConfig with an Ingress

Modify an AlbConfig

You can modify the settings of an AlbConfig, such as the name and the vSwitches of the AlbConfig.

The new settings take effect immediately after you save the settings.

Enable Simple Log Service to collect access logs

If you want to collect the access logs of ALB Ingresses, configure the logProject and logStore parameters of an AlbConfig.

Note
  • Simple Log Service projects are not automatically created. You must manually create a Simple Log Service project. For more information, see Manage projects.

  • Set the logStore parameter to a value that starts with alb_. If the specified Logstore does not exist, the system automatically creates one with the specified name.

Enable Simple Log Service to collect access logs

Enable Simple Log Service to collect access logs

Use an existing ALB instance

If you want to use an existing ALB instance, specify the ID of the ALB instance when you create an AlbConfig.

Reuse an existing ALB instance

Reuse an existing ALB instance

Use multiple ALB instances

If you want to use multiple ALB instances, specify multiple IngressClasses in the spec.ingressClassName field of the Ingress.

Create and use multiple ALB instances

Create and use multiple ALB instances

Delete an ALB instance

An AlbConfig is used to configure an ALB instance. Therefore, you can delete an ALB instance by deleting the corresponding AlbConfig. Before you delete an AlbConfig, you must delete all Ingresses that are associated with the AlbConfig.

Delete an ALB instance

Delete an ALB instance

Listener management

Specify a certificate for HTTPS connections

You can specify a certificate for an ALB instance by specifying the certificate ID in the listeners parameter of the corresponding AlbConfig. The certificate is used for HTTPS connections.

Use an ALB Ingress to configure certificates for an HTTPS listener

Use an ALB Ingress to configure certificates for an HTTPS listener

Specify a Transport Layer Security (TLS) security policy

When you use an AlbConfig to configure an HTTPS listener, you can specify a TLS security policy. Custom and default TLS security policies are supported. For more information, see TLS security policies.

Specify a custom TLS security policy

Specify a custom TLS security policy

Advanced features

An Ingress is an API object that you can use to implement Layer 7 load balancing and manage external access to Services in an ACK cluster. The following table describes how to use ALB Ingresses to forward requests to backend server groups based on domain names and URL paths, redirect requests from HTTP to HTTPS, and perform canary releases.

Feature

Description

References for ACK

References for ACK Serverless

Forward requests based on domain names

You can create an Ingress with or without a domain name, and then use the Ingress to forward requests.

Forward requests based on domain names

Forward requests based on domain names

Forward requests based on URL paths

ALB Ingresses can forward requests based on URL paths. You can use the pathType parameter to configure different URL match policies. The valid values of pathType are Exact, ImplementationSpecific, and Prefix.

Forward requests based on URL paths

Forward requests based on URL paths

Custom forwarding rules

ALB Ingresses allow you to configure custom forwarding rules. A forwarding rule consists of match conditions and actions. ALB Ingresses support the following operations:

  • Specify custom forwarding conditions, such as domain names, URLs, request headers, query strings, request methods, cookies, and source IP addresses by configuring the alb.ingress.kubernetes.io/conditions.<Service name> annotation.

  • Specify custom forwarding actions to return fixed responses, redirect requests, insert request headers, mirror traffic, forward requests to multiple server groups, or rewrite requests by configuring the alb.ingress.kubernetes.io/actions.<Service name> annotation.

  • Specify custom forwarding conditions in the ACK console, such as domain names, URLs, and HTTP headers.

  • Specify custom forwarding actions in the ACK console to forward requests to specified server groups or return fixed responses.

Important
  • Each forwarding rule supports at most 10 forwarding conditions.

  • Routing conditions ResponseHeader and ResponseStatusCode take effect only in custom outbound routing rules.

Create custom forwarding rules for ALB Ingresses

Create custom forwarding rules for ALB Ingresses

Configure health checks

You can add annotations to ALB Ingresses to configure health checks. Health check parameters include path, protocol, method, httpcode, timeout, interval, and threshold.

Configure health checks

Configure health checks

Configure automatic certificate discovery

The ALB Ingress controller supports automatic certificate discovery. You must first create a certificate in the Certificate Management Service console. Then, specify the domain name of the certificate in the TLS configurations of the Ingress. This way, the ALB Ingress controller can automatically discover and match the certificate based on the TLS configurations of the Ingress.

Use an ALB Ingress to configure certificates for an HTTPS listener

Use an ALB Ingress to configure certificates for an HTTPS listener

Configure a redirect from HTTP requests to HTTPS requests

You can configure an ALB Ingress to redirect HTTP requests to HTTPS (port 443) by adding the alb.ingress.kubernetes.io/ssl-redirect: "true" annotation.

Redirect HTTP requests to HTTPS

Redirect HTTP requests to HTTPS

Configure the HTTPS or gRPC protocol

ALB Ingresses support the HTTPS or gRPC protocol. To configure HTTPS or gRPC, add the alb.ingress.kubernetes.io/backend-protocol: "grpc" or alb.ingress.kubernetes.io/backend-protocol: "https" annotation. If you want to use an Ingress to distribute requests to a gRPC service, you must configure an SSL certificate for the gRPC service and use the TLS protocol to communicate with the gRPC service.

Note

You cannot change the backend protocol. If you need to change the protocol, delete and rebuild the Ingress.

Configure HTTPS or gRPC as the backend protocol

Configure HTTPS or gRPC as the backend protocol

Configure rewrite rules

ALB Ingresses support rewrite rules. To configure rewrite rules, add the alb.ingress.kubernetes.io/rewrite-target: /path/${2} annotation.

Note
  • In the rewrite-target annotation, you must set the type of the path parameter to Prefix for a capturing group of the ${number} type.

  • By default, the path parameter does not support characters that are supported by regular expressions, such as asterisks (*) and question marks (?). To specify characters that are supported by regular expressions in the path parameter, you must add the rewrite-target annotation.

  • The value of the path parameter must start with a forward slash (/).

Configure rewrite rules

Configure rewrite rules

Configure custom listening ports

ALB Ingresses allow you to configure custom listening ports to expose multiple ports at the same time. You can use this method to expose both port 80 and port 443 of a Service to the internet.

Configure custom listening ports

Configure custom listening ports

Configure forwarding rule priorities

You can add an annotation to the configuration of an Ingress to configure the priorities of the forwarding rules of the Ingress.

Note

The priority of each forwarding rule within a listener is unique. You can use the alb.ingress.kubernetes.io/order annotation to specify the priorities of the forwarding rules of an Ingress. Valid values: 1 to 1000. A lower value indicates a higher priority.

Configure forwarding rule priorities

Configure forwarding rule priorities

Use annotations to perform canary releases

ALB allows you to configure canary releases based on request headers, cookies, and weights to handle complex traffic routing. You can add annotations to configure canary releases.

You can add the alb.ingress.kubernetes.io/canary: "true" annotation to enable the canary release feature. Then, you can use different annotations to configure different canary release rules.

Configure session persistence

You can configure session persistence for an ALB Ingress by adding the alb.ingress.kubernetes.io/sticky-session and alb.ingress.kubernetes.io/sticky-session-type annotations.

Configure session persistence by using annotations

Configure session persistence by using annotations

Specify a load balancing algorithm for backend server groups

You can specify a load balancing algorithm for backend server groups by adding the alb.ingress.kubernetes.io/backend-scheduler annotation.

Specify the scheduling algorithm

Specify the scheduling algorithm

Configure cross-origin resource sharing (CORS)

ALB Ingresses allow you to configure CORS by using annotations.

Configure CORS

Configure CORS

Configure persistent TCP connections

Each time a traditional load balancer forwards a request to a backend server, it creates a short-lived connection. This action causes unnecessary load on the server and performance bottleneck issues. ALB provides the persistent TCP connection feature, which reduces the amount of resources consumed for establishing network connections and improves forwarding performance. You can add the alb.ingress.kubernetes.io/backend-keepalive annotation to the ALB Ingress to enable the persistent TCP connection feature.

Configure persistent TCP connections

Configure persistent TCP connections

Configure QPS throttling

ALB supports QPS throttling based on forwarding rules. You can limit the QPS to a range of 1 to 100000. You can add the alb.ingress.kubernetes.io/traffic-limit-qps annotation to the ALB Ingress to enable the QPS throttling feature.

Configure QPS throttling

Configure QPS throttling

Backend slow start

You can add the alb.ingress.kubernetes.io/slow-start-enabled annotation to enable slow start mode for an ALB Ingress. Add the alb.ingress.kubernetes.io/slow-start-duration annotation to configure the time it takes for the slow start to gradually increase traffic. Valid values range from 30 to 900 seconds.

Note

The longer the duration, the slower the increase in traffic.

Backend slow start

Backend slow start

Connection draining

You can add the alb.ingress.kubernetes.io/connection-drain-enabled annotation to enable connection draining for an ALB Ingress. Add the alb.ingress.kubernetes.io/connection-drain-timeout annotation to configure the connection draining timeout period. Valid values range from 0 to 900 seconds.

Connection draining

Connection draining

  • Specify both Kubernetes pods and Elastic Compute Service (ECS) instances as backend servers

  • Use Cloud Enterprise Network (CEN) and transit routers to specify cross-region resources and data centers as backend servers

  • ALB Ingresses allow you to use the alb.ingress.kubernetes.io/actions.<Service name> annotation to configure backend server groups for ALB instances. You can add both Kubernetes pods and ECS instances as backend servers for ALB instances by specifying Service names and server group IDs.

  • You can attach ALB instances to CEN and transit routers to forward requests from ALB to servers in VPCs that are deployed in a different region than ALB and to data centers.

Use ALB Ingresses to configure hybrid backend server groups, associate ECS instances with an ALB instance deployed in a different region, and associate on-premises servers with an ALB instance

Use ALB Ingresses to configure hybrid backend server groups, associate ECS instances with an ALB instance deployed in a different region, and associate on-premises servers with an ALB instance

Integration with other services

Integration with Alibaba Cloud services

Alibaba Cloud service

Feature

Description

References

WAF

Enable Web Application Firewall (WAF) for an ALB Ingress

Web Application Firewall (WAF) is an all-in-one service that protects your websites and applications. You can use WAF to prevent data breaches, HTTP flood attacks, webshells, and web page tampering. WAF also provides virtual patches. After you enable WAF for an ALB Ingress, network traffic is filtered by WAF before it is routed to ALB listeners.

Enable WAF for an ALB Ingress

EDAS

Create an ALB Ingress for an application

EDAS supports ALB Ingresses. ALB Ingresses provide enhanced traffic management and are compatible with NGINX Ingresses. This enables ALB Ingresses to process complex routing and automatically discover certificates.

Create an ALB Ingress

SAE

Configure an end-to-end canary release based on Ingress gateways

You can use Ingress gateways to perform end-to-end canary releases for SAE applications.

ASM

Integrate Service Mesh (ASM) with ALB by configuring an ALB Ingress

You can configure an ALB Ingress to integrate ASM with ALB.

Integrate ASM with ALB

HPA

Integrate Horizontal Pod Autoscaler (HPA) with ALB by configuring an ALB Ingress

HPA is used to automatically scale out pods in Kubernetes clusters. You can integrate HPA with ALB by using ALB Ingresses and enable auto scaling based on queries per second (QPS).

Use ALB Ingresses to enable automatic application scaling based on QPS

Knative

Enable ACK and ACK Serverless clusters that have Knative installed to access services through ALB

Knative is a Kubernetes-based serverless framework. You can use Knative to expose your ALB Service and perform canary releases based on headers and cookies.

Use ALB Ingresses in Knative

ACK One

Create an ALB multi-cluster gateway by configuring an ALB Ingress

Distributed Cloud Container Platform for Kubernetes (ACK One) is an enterprise-class cloud-native container platform developed by Alibaba Cloud to meet container management requirements in hybrid cloud, multi-cluster, distributed computing, and disaster recovery scenarios. The ALB multi-cluster gateways provided by ACK One are the multi-cluster mode of ALB Ingresses. You can use them to implement active zone-redundancy, active geo-redundancy, cross-cluster load balancing, and header-based traffic distribution to only the specified cluster.

Integration with open source services

Open source service

Feature

Description

References

Self-managed Kubernetes clusters in the cloud

Use ALB in self-managed Kubernetes clusters by configuring ALB Ingresses

If you use ECS instances to build a Kubernetes cluster, you can configure an ALB Ingress to route traffic. This enables the cluster to automatically discover the ALB Service and enable load balancing.

Use ALB Ingresses on self-managed Kubernetes clusters