Configure Ingress for your app in Azure Container Apps

This article shows you how to enable ingress features for your container app. Ingress is an application-wide setting. Changes to ingress settings apply to all revisions simultaneously, and don't generate new revisions.

Ingress settings

You can set the following ingress template properties:

Property Description Values Required
allowInsecure Allows insecure traffic to your container app. When set to true HTTP requests to port 80 aren't automatically redirected to port 443 using HTTPS, allowing insecure connections. false (default), true enables insecure connections No
clientCertificateMode Client certificate mode for mTLS authentication. Ignore indicates server drops client certificate on forwarding. Accept indicates server forwards client certificate but doesn't require a client certificate. Require indicates server requires a client certificate. Required, Accept, Ignore (default) No
customDomains Custom domain bindings for Container Apps' hostnames. See Custom domains and certificates An array of bindings No
exposedPort (TCP ingress only) The port TCP listens on. If external is true, the value must be unique in the Container Apps environment. A port number from 1 to 65535. (can't be 80 or 443) No
external Allow ingress to your app from outside its Container Apps environment. true or false(default) Yes
ipSecurityRestrictions IP ingress restrictions. See Set up IP ingress restrictions An array of rules No
stickySessions.affinity Enables session affinity. none (default), sticky No
targetPort The port your container app listens to for incoming requests. Set this value to the port number that your container app uses. For HTTP ingress, your application ingress endpoint is always exposed on port 443. Yes
traffic Traffic splitting weights split between revisions. An array of rules No
transport The transport protocol type. auto (default) detects HTTP/1 or HTTP/2, http for HTTP/1, http2 for HTTP/2, tcp for TCP. No

Automatic port detection

If your container app has HTTP ingress enabled and you have not set a target port, Azure Container Apps will automatically detect the target port by scanning all listening ports on your container. If there is only one port detected, that port will be set as the target port for your container app. If there is more than 1 port detected, the container app will not automatically set the target port, and you will need to set the target port manually.

  • Automatic port detection only works for HTTP traffic, not TCP traffic.
  • If you have HTTP health probes listening on ports 80 or 443, this can interfere with automatic port detection. The default ingress configuration uses TCP health probes. For more information see health probes.

Enable ingress

You can configure ingress for your container app using the Azure CLI, an ARM template, or the Azure portal.

This az containerapp ingress enable command enables ingress for your container app. You must specify the target port, and you can optionally set the exposed port if your transport type is tcp.

az containerapp ingress enable \
    --name <app-name> \
    --resource-group <resource-group> \
    --target-port <target-port> \
    --exposed-port <tcp-exposed-port> \
    --transport <transport> \
    --type <external>
    --allow-insecure

az containerapp ingress enable ingress arguments:

Option Property Description Values Required
--type external Allow ingress to your app from anywhere, or limit ingress to its internal Container Apps environment. external or internal Yes
--allow-insecure allowInsecure Allow HTTP connections to your app. No
--target-port targetPort The port your container listens to for incoming requests. Set this value to the port number that your container uses. Your application ingress endpoint is always exposed on port 443. Yes
--exposed-port exposedPort (TCP ingress only) An port for TCP ingress. If external is true, the value must be unique in the Container Apps environment if ingress is external. A port number from 1 to 65535. (can't be 80 or 443) No
--transport transport The transport protocol type. auto (default) detects HTTP/1 or HTTP/2, http for HTTP/1, http2 for HTTP/2, tcp for TCP. No

Enable ingress for your container app by using the portal.

You can enable ingress when you create your container app, or you can enable ingress for an existing container app.

  • To configure ingress when you create your container app, select Ingress from the App Configuration tab of the container app creation wizard.
  • To configure ingress for an existing container app, select Ingress from the Settings menu of the container app resource page.

Enabling ingress for your container app:

You can configure ingress when you create your container app by using the Azure portal.

  1. Set Ingress to Enabled.
  2. Configure the ingress settings for your container app.
  3. Select Limited to Container Apps Environment for internal ingress or Accepting traffic from anywhere for external ingress.
  4. Select the Ingress Type: HTTP or TCP (TCP ingress is only available in environments configured with a custom virtual network).
  5. If HTTP is selected for the Ingress Type, select the Transport: Auto, HTTP/1 or HTTP/2.
  6. Select Insecure connections if you want to allow HTTP connections to your app.
  7. Enter the Target port for your container app.
  8. If you selected TCP for the Transport option, enter the Exposed port for your container app. The exposed port number can be 1 to 65535. (can't be 80 or 443)

The Ingress settings page for your container app also allows you to configure IP Restrictions. For information to configure IP restriction, see IP Restrictions.

Enable ingress for your container app by using the ingress configuration property. Set the external property to true, and set your transport and targetPort properties. -external property can be set to true for external or false for internal ingress.

  • Set the transport to auto to detect HTTP/1 or HTTP/2, http for HTTP/1, http2 for HTTP/2, or tcp for TCP.
  • Set the targetPort to the port number that your container uses. Your application ingress endpoint is always exposed on port 443.
  • Set the exposedPort property if transport type is tcp to a port for TCP ingress. The value must be unique in the Container Apps environment if ingress is external. A port number from 1 to 65535. (can't be 80 or 443)
{
  ...
  "configuration": {
    "ingress": {
        "external": true,
        "transport": "tcp",
        "targetPort": 80,
        "exposedPort": 8080,
    },
  }
}

Disable ingress

Disable ingress for your container app by using the az containerapp ingress command.

az containerapp ingress disable \
    --name <app-name> \
    --resource-group <resource-group> \

You can disable ingress for your container app using the portal.

  1. Select Ingress from the Settings menu of the container app page.
  2. Deselect the Ingress Enabled setting.
  3. Select Save.

Screenshot of disabling container app ingress.

Disable ingress for your container app by omitting the ingress configuration property from properties.configuration entirely.

Use other TCP ports

You can expose additional TCP ports from your application. To learn more, see the ingress concept article.

Note

To use this feature, you must have the container apps CLI extension. Run az extension add -n containerapp in order to install the latest version of the container apps CLI extension.

Adding other TCP ports can be done through the CLI by referencing a YAML file with your TCP port configurations.

az containerapp create \
    --name <app-name> \
    --resource-group <resource-group> \
    --yaml <your-yaml-file>

The following is an example YAML file you can reference in the above CLI command. The configuration for the additional TCP ports is under additionalPortMappings.

location: northcentralus
name: multiport-example
properties:
  configuration:
    activeRevisionsMode: Single
    ingress:
      additionalPortMappings:
      - exposedPort: 21025
        external: false
        targetPort: 1025
      allowInsecure: false
      external: true
      targetPort: 1080
      traffic:
      - latestRevision: true
        weight: 100
      transport: http
  managedEnvironmentId: <env id>
  template:
    containers:
    - image: maildev/maildev
      name: maildev
      resources:
        cpu: 0.25
        memory: 0.5Gi
    scale:
      maxReplicas: 1
      minReplicas: 1
  workloadProfileName: Consumption
type: Microsoft.App/containerApps

Screenshot of adding additional TCP ports for Container Apps ingress through the portal.

  1. Expand the Additional TCP ports section within the Ingress blade.
  2. Add in additional TCP ports that your application will be accepting traffic on in the Target port field. If Exposed port is left empty, this will take from the same value set in Target port.
  3. Change the Ingress traffic field as needed. This will configure where ingress traffic will be limited to for each port.
  4. When finished, click Save.

The following ARM template provides an example of how you can add additional ports to your container apps. Each additional port should be added under additionalPortMappings within the ingress section for configuration within properties for the container app. The following is an example:

{
  ...
  "properties": {
    ...
    "configuration": {
      "ingress": {
        ...
        "additionalPortMappings": [
          {
            "external": false
            "targetPort": 80
            "exposedPort": 12000
          }
        ]
      }
    }
  ...
}

Next steps