Queue Storage
Introduction
Section titled “Introduction”Azure Queue Storage is a messaging service for storing large numbers of messages that can be accessed from anywhere over HTTP or HTTPS. It is commonly used to decouple application components and build asynchronous processing workflows. Queue Storage is useful for buffering work items between producers and consumers. For more information, see What is Azure Queue Storage?
LocalStack for Azure provides a local environment for building and testing applications that make use of Azure Queue Storage. The supported APIs are available on our API Coverage section, which provides information on the extent of Queue Storage’s integration with LocalStack.
Getting started
Section titled “Getting started”This guide is designed for users new to Queue Storage and assumes basic knowledge of the Azure CLI and our azlocal wrapper script.
Start your LocalStack container using your preferred method. For more information, see Introduction to LocalStack for Azure.
[!NOTE] As an alternative to using the
azlocalCLI, customers can runaz start-interception. This command points theazCLI away from the public Azure cloud management API and toward the local emulator API. To revert this configuration, useazlocal stop-interception, which re-configures the CLI to send commands to the official Azure platform management REST API. At this time, there is no full parity betweenazlocalcommands andazcommands after runningaz start-interception. Therefore, this technique is not fully interchangeable.
Create a resource group
Section titled “Create a resource group”Create a resource group to contain your storage resources:
azlocal group create \ --name rg-queue-demo \ --location westeurope{ "id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-queue-demo", "location": "westeurope", "managedBy": null, "name": "rg-queue-demo", "properties": { "provisioningState": "Succeeded" }, "tags": null, "type": "Microsoft.Resources/resourceGroups"}Create a storage account
Section titled “Create a storage account”Create an Azure storage account for Queue Storage:
azlocal storage account create \ --name stqueuedemols \ --resource-group rg-queue-demo \ --location westeurope \ --sku Standard_LRS{ ... "id": "/subscriptions/00000000-0000-0000-0000-000000000000/resourceGroups/rg-queue-demo/providers/Microsoft.Storage/storageAccounts/stqueuedemols", ... "name": "stqueuedemols", ... "placement": null, "primaryEndpoints": { "blob": "https://stqueuedemolsblob.localhost.localstack.cloud:4566", ... "queue": "https://stqueuedemolsqueue.localhost.localstack.cloud:4566", ... }, ....}Authentication
Section titled “Authentication”There are three ways to authenticate storage queue commands against the emulator:
Storage account key
Section titled “Storage account key”Retrieve the account key and pass it with --account-name and --account-key:
ACCOUNT_KEY=$(azlocal storage account keys list \ --account-name stqueuedemols \ --resource-group rg-queue-demo \ --query "[0].value" \ --output tsv)
azlocal storage queue list \ --account-name stqueuedemols \ --account-key "$ACCOUNT_KEY"Login credentials
Section titled “Login credentials”Use --auth-mode login to authenticate with the current session credentials:
azlocal storage queue list \ --account-name stqueuedemols \ --auth-mode loginConnection string
Section titled “Connection string”Bundle the account name and key into a single value:
CONNECTION_STRING=$(azlocal storage account show-connection-string \ --name stqueuedemols \ --resource-group rg-queue-demo \ --query connectionString -o tsv)
azlocal storage queue list \ --connection-string "$CONNECTION_STRING"The remaining examples in this guide use connection strings for brevity.
Create and inspect a queue
Section titled “Create and inspect a queue”Create a queue:
azlocal storage queue create \ --name app-queue \ --connection-string "$CONNECTION_STRING"{ "created": true}Verify the queue exists:
azlocal storage queue exists \ --name app-queue \ --connection-string "$CONNECTION_STRING"{ "exists": true}List queues in the storage account:
azlocal storage queue list \ --connection-string "$CONNECTION_STRING"[ { "approximateMessageCount": null, "metadata": null, "name": "app-queue" }]Put, peek, and get messages
Section titled “Put, peek, and get messages”Add a message to the queue:
azlocal storage message put \ --queue-name app-queue \ --content "hello-from-localstack" \ --connection-string "$CONNECTION_STRING"{ "content": "hello-from-localstack", ... "id": "a253ff4a-7b9c-434e-9c33-deae3070193c", ...}Peek at messages without consuming them:
azlocal storage message peek \ --queue-name app-queue \ --connection-string "$CONNECTION_STRING"[ { "content": "hello-from-localstack", ... "id": "a253ff4a-7b9c-434e-9c33-deae3070193c", "insertionTime": "2026-02-27T07:45:14+00:00", ... }]Get (dequeue) a message from the queue, which makes it invisible to other consumers for the visibility timeout period:
azlocal storage message get \ --queue-name app-queue \ --connection-string "$CONNECTION_STRING" \ --output json[ { "content": "hello-from-localstack", ... "id": "a253ff4a-7b9c-434e-9c33-deae3070193c", "popReceipt": "...", ... }]Features
Section titled “Features”The Queue Storage emulator supports the following features:
- Data plane REST API: Queue CRUD, message operations (put, peek, get, delete), queue metadata, stored access policies, and SAS token generation.
- Control plane (ARM) REST API: Create and get queues, get and set queue service properties via Azure Resource Manager.
- Multiple authentication modes: Storage account key, login credentials, and connection strings.
Limitations
Section titled “Limitations”- No data persistence across restarts: Queue data is not persisted and is lost when the LocalStack emulator is stopped or restarted.
- Queue endpoint URL: The service type is appended to the account name (
{account}queue.localhost.localstack.cloud:{port}) rather than used as a subdomain ({account}.queue.core.windows.net). - Queue service properties:
set_service_propertiesis a no-op andget_service_propertiesreturns empty defaults, unlike Azure where CORS, logging, and metrics settings are persisted and applied. - Storage account keys: Keys are emulator-generated rather than managed by Azure.
- Header validation: Unsupported request headers or parameters are silently accepted instead of being rejected.
- API version enforcement: The emulator does not validate the
x-ms-versionheader; all API versions are accepted.
Configuration
Section titled “Configuration”The following environment variables can be set on the LocalStack container to customize Queue Storage behavior:
STORAGE_EXPOSE_AZURITE_PORTS: When set tofalse, internal storage ports are not mapped to the host, disabling direct connectivity to the storage backend. Defaults totrue.
Samples
Section titled “Samples”The following sample demonstrates how to use Queue Storage with LocalStack for Azure:
API Coverage
Section titled “API Coverage”| Operation ▲ | Implemented ▼ |
|---|