Connect to services in Azure Container Apps (preview)

As you develop applications in Azure Container Apps, you often need to connect to different services. Rather than creating services ahead of time and manually connecting them to your container app, you can quickly create instances of development-grade services that are designed for nonproduction environments known as add-ons.

Add-ons allow you to use OSS services without the burden of manual downloads, creation, and configuration.

Once you're ready for your app to use a production level service, you can connect your application to an Azure managed service.

Services available as an add-on include:

Title Service name
Kafka kafka
MariaDB mariadb
Milvus milvus
PostgreSQL (open source) postgres
Qdrant qdrant
Redis (open source) redis
Weaviate weaviate

You can get most recent list of add-on services by running the following command:

az containerapp add-on --help

See the section on how to manage a service for usage instructions.

Features

Add-ons come with the following features:

  • Scope: The add-on runs in the same environment as the connected container app.
  • Scaling: The add-on can scale in to zero when there's no demand for the service.
  • Pricing: Add-on billing falls under consumption-based pricing. Billing only happens when instances of the add-on are running.
  • Storage: The add-on uses persistent storage to ensure there's no data loss as the add-on scales in to zero.
  • Revisions: Anytime you change an add-on, a new revision of your container app is created.

See the service-specific features for managed services.

Binding

Both add-ons and managed services connect to a container via a binding.

The Container Apps runtime binds a container app to a service by:

  • Discovering the service
  • Extracting networking and connection configuration values
  • Injecting configuration and connection information into container app environment variables

Once a binding is established, the container app can read these configuration and connection values from environment variables.

Development vs production

As you move from development to production, you can move from an add-on to a managed service.

The following table shows you which service to use in development, and which service to use in production.

Functionality Add on Production managed service
Cache Open-source Redis Azure Cache for Redis
Database N/A Azure Cosmos DB
Database Open-source PostgreSQL Azure Database for PostgreSQL Flexible Server

You're responsible for data continuity between development and production environments.

Manage a service

To connect a service to an application, you first need to create the service.

Use the az containerapp add-on <SERVICE_TYPE> create command with the service type and name to create a new service.

az containerapp add-on redis create \
  --name myredis \
  --environment myenv

This command creates a new Redis service called myredis in a Container Apps environment called myenv.

To bind a service to an application, use the --bind argument for containerapp create.

az containerapp create \
  --name myapp \
  --image myimage \
  --bind myredis \
  --environment myenv

This command features the typical Container App create with the --bind argument. The bind argument tells the Container Apps runtime to connect a service to the application.

The --bind argument is available to the create or update commands.

To disconnect a service from an application, use the --unbind argument on the update command

The following example shows you how to unbind a service.

az containerapp update --name myapp --unbind myredis

For more information on the service commands and arguments, see the az containerapp reference.

Limitations

  • Add-ons are in public preview.
  • Any container app created before May 23, 2023 isn't eligible to use add-ons.
  • Add-ons come with minimal guarantees. For instance, they're automatically restarted if they crash, however there's no formal quality of service or high-availability guarantees associated with them. For production workloads, use Azure-managed services.
  • If you use your own VNET, you must use a workload profiles environment. The Add-ons feature is not supported in consumption only environments that use custom VNETs.