What is Application Gateway for Containers?
Application Gateway for Containers is an application layer (layer 7) load balancing and dynamic traffic management product for workloads running in a Kubernetes cluster. It extends Azure's Application Load Balancing portfolio and is a new offering under the Application Gateway product family.
Application Gateway for Containers is the evolution of the Application Gateway Ingress Controller (AGIC), a Kubernetes application that enables Azure Kubernetes Service (AKS) customers to use Azure's native Application Gateway application load-balancer. In its current form, AGIC monitors a subset of Kubernetes Resources for changes and applies them to the Application Gateway, utilizing Azure Resource Manager (ARM).
How does it work?
Application Gateway for Containers is made up of three components:
- Application Gateway for Containers resource
- Frontends
- Associations
The following dependencies are also referenced in an Application Gateway for Containers deployment:
- Private IP address
- Subnet Delegation
- User-assigned Managed Identity
The architecture of Application Gateway for Containers is summarized in the following figure:
For details about how Application Gateway for Containers accepts incoming requests and routes them to a backend target, see Application Gateway for Containers components.
Features and benefits
Application Gateway for Containers offers some entirely new features at release, such as:
- Traffic splitting / Weighted round robin
- Mutual authentication to the backend target
- Kubernetes support for Ingress and Gateway API
- Flexible deployment strategies
- Increased performance, offering near real-time updates to add or move pods, routes, and probes
Application Gateway for Containers offers an elastic and scalable ingress to AKS clusters and comprises a new data plane as well as control plane with new set of ARM APIs, different from existing Application Gateway. These APIs are different from the current implementation of Application Gateway. Application Gateway for Containers is outside the AKS cluster data plane and is responsible for ingress. The service is managed by an ALB controller component that runs inside the AKS cluster and adheres to Kubernetes Gateway APIs.
Load balancing features
Application Gateway for Containers supports the following features for traffic management:
- Automatic retries
- Autoscaling
- Availability zone resiliency
- Custom and default health probes
- ECDSA and RSA certificate support
- gRPC
- Header rewrite
- HTTP/2
- HTTPS traffic management:
- SSL termination
- End to End SSL
- Ingress and Gateway API support
- Layer 7 HTTP/HTTPS request forwarding based on prefix/exact match on:
- Hostname
- Path
- Header
- Query string
- Methods
- Ports (80/443)
- Mutual authentication (mTLS) to frontend, backend, or end-to-end
- Server-sent event (SSE) support
- Traffic splitting / weighted round robin
- TLS policies
- URL redirect
- URL rewrite
- WebSocket support
Deployment strategies
There are two deployment strategies for management of Application Gateway for Containers:
- Bring your own (BYO) deployment: In this deployment strategy, deployment and lifecycle of the Application Gateway for Containers resource, Association resource, and Frontend resource is assumed via Azure portal, CLI, PowerShell, Terraform, etc. and referenced in configuration within Kubernetes.
- In Gateway API: Every time you wish to create a new Gateway resource in Kubernetes, a Frontend resource should be provisioned in Azure prior and referenced by the Gateway resource. Deletion of the Frontend resource is responsible by the Azure administrator and isn't deleted when the Gateway resource in Kubernetes is deleted.
- Managed by ALB Controller: In this deployment strategy, ALB Controller deployed in Kubernetes is responsible for the lifecycle of the Application Gateway for Containers resource and its sub resources. ALB Controller creates the Application Gateway for Containers resource when an ApplicationLoadBalancer custom resource is defined on the cluster and its lifecycle is based on the lifecycle of the custom resource.
- In Gateway API: Every time a Gateway resource is created referencing the ApplicationLoadBalancer resource, ALB Controller provisions a new Frontend resource and manage its lifecycle based on the lifecycle of the Gateway resource.
Supported regions
Application Gateway for Containers is currently offered in the following regions:
- Australia East
- Canada Central
- Central India
- Central US
- East Asia
- East US
- East US2
- France Central
- Germany West Central
- Korea Central
- North Central US
- North Europe
- Norway East
- South Central US
- Southeast Asia
- Switzerland North
- UAE North
- UK South
- West US
- West Europe
Implementation of Gateway API
ALB Controller implements version v1 of the Gateway API.
Gateway API Resource | Support | Comments |
---|---|---|
GatewayClass | Yes | |
Gateway | Yes | Support for HTTP and HTTPS protocol on the listener. The only ports allowed on the listener are 80 and 443. |
HTTPRoute | Yes | |
ReferenceGrant | Yes | Currently supports version v1alpha1 of this API |
Implementation of Ingress API
ALB Controller implements support for Ingress.
Ingress API Resource | Support | Comments |
---|---|---|
Ingress | Yes | Support for HTTP and HTTPS protocol on the listener. |
Report issues and provide feedback
For feedback, post a new idea in feedback.azure.com For issues, raise a support request via the Azure portal on your Application Gateway for Containers resource.
Pricing and SLA
For Application Gateway for Containers pricing information, see Application Gateway pricing.
For Application Gateway for Containers SLA information, see Service Level Agreements (SLA) for Online Services.
What's new
To learn what's new with Application Gateway for Containers, see Azure updates.