This is the Trace Id: c14ea5b33d79e26af4bfffb00c0c6cf0
Skip to main content
Azure

Azure Container Storage

Power stateful containerized workloads with intelligent, cloud-native storage

Unlock high-performance storage for your Kubernetes workloads

Azure Container Storage is a volume-management service built natively for Azure Kubernetes Service (AKS). Simplify creating and managing persistent volumes for production-scale stateful container applications. Use the free managed service in Azure or the open-source version across any Kubernetes cluster.

Azure Container Storage v2.0.0 is here! Up to 7× faster, open- source, and free of service fees. Learn more.

Achieve fully managed persistent volume deployment and unified volume management for various back-end storage options

Create simple and consistent volume orchestration for stateful workloads via the Kubernetes control plane

Leverage local NVMe drives on select virtual machine families to provide rapid storage for Kubernetes workloads

Quickly scale stateful containers with persistent volumes

Accelerate high-performance stateful workloads

Run stateful container applications on Kubernetes with the high performance of locally attached NVMe disks.

Use Azure Container Storage with local NVMe

A person wearing protective goggles and headwear working with cables in a server room
Colorful shipping containers

Enable Kubernetes-native volume orchestration

Deploy and manage persistent storage volumes for stateful container applications in AKS, such as PostgreSQL, Kafka, Valkey, and more. Azure Container Storage enables full lifecycle control—including snapshots and storage pools—without switching between platforms.

Use Azure Container Storage with Azure Kubernetes Service (AKS)

Run stateful workloads with ease

Orchestrate volumes consistently using Kubernetes-native APIs for reliable, scalable storage that behaves like part of your application.

Workload samples

A person holding a tablet displaying data in charts and graphs
A presenter pointing to data on a large screen in front a group of attendees in a conference room

Grow with confidence

Rapidly scale out containerized applications with persistent volumes that expand with your demands.

Resize persistent volumes in Azure Container Storage without downtime

Achieve open-source freedom for Kubernetes storage

Run Azure Container Storage with our fully open-source implementation. Install on a Kubernetes cluster, contribute to the project, and customize for your environment, all while benefiting from the same performance and features as the Azure-managed version.

GitHub repository

Video container

Built-in security and compliance

A security center overview in Azure showing policy and compliance data and resource security hygiene
The security center compute and apps tab in Azure showing a list of recommendations

Get started with an Azure free account

1

Start free. Get $200 credit to use within 30 days. While you have your credit, get free amounts of many of our most popular services, plus free amounts of 55+ other services that are always free.

2

After your credit, move to pay as you go to keep building with the same free services. Pay only if you use more than your free monthly amounts.

3

After 12 months, you'll keep getting 55+ always-free services—and still pay only for what you use beyond your free monthly amounts.

Azure Container Storage resources and documentation

Blog and updates

Read the Azure blog and subscribe to Azure updates for the latest news and information about Azure Container Storage.

Community and Azure support

Ask questions and get support from Microsoft engineers and Azure community experts.

Chat with an Azure support specialist.

Frequently asked questions about Azure Container Storage

  • Azure Container Storage supports only Azure Kubernetes Service (AKS) today. Deploy and manage volumes consistently across various backend storage options such as local storage and persistent block storage while using AKS.

  • Azure Container Storage is built natively for containers and provides a storage solution that is highly optimized for creating and managing volumes for running production-scale stateful container applications. It provides higher performance and availability than Azure CSI drivers. Additionally, Azure Container Storage supports storage types such as local volumes and storage area network (SAN), which are not supported by Azure CSI drivers.

  • Azure Container Storage works well for all stateful ReadWriteOnce (RWO) workloads.

  • Yes. See the Quickstart to learn how to enable Azure Container Storage in an existing AKS cluster.

Ready when you are—let's set up your Azure free account

Try Azure for free
#chatEngagement { color: #fff; background-color: #006abb; border: 1px solid #0078d4; border-radius: 4px; display: inline-block; font-size: 14px; font-weight: 600; padding: 10px 16px; } #chatEngagement:hover, #chatEngagement:active { text-decoration: underline; } #chatDisengagement { color: #0062ad; display: inline-block; font-size: 14px; font-weight: 600; padding-right: 1em; position: relative; text-decoration: none; border: none; background-color: transparent; } #chatEngagement:focus { outline: 1px solid #fff; outline-offset: -4px; text-decoration: underline; } #chatDisengagement:after { background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 12 12' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 1L9 6L4 11' stroke='%230062ad'/%3E%3C/svg%3E"); content: ' '; height: 12px; width: 12px; display: inline-flex; vertical-align: middle; margin-left: .2em; transition: all .2s ease-in-out; position: absolute; bottom: -6px; background-color: transparent; } #chatDisengagement:focus { outline-offset: 10px; } #lp-iframe-container { border: 0; bottom: 0; box-shadow: 0 5px 15px 0 #00000033; height: 500px; left: auto !important; min-width: 300px; max-width: 350px; padding: 0; position: fixed; right: 0; top: auto !important; z-index: 1031; } #iFrame { height: 100%; width: 100%; border: 0; } #proactive-chat-dialog { position: fixed; z-index: 10400; bottom: -24px; right: 11px; } #proactive-chat-dialog .chatContainer { min-width: 272px; height: 277px; color: #000; line-height: 0; position: relative; border: 0 !important; background-repeat: no-repeat !important; background-color: #fff !important; margin: auto; padding: 12px; background-size: contain !important; box-shadow: 0 2.8px 2.2px rgba(0, 0, 0, 0.034), 0 6.7px 5.3px rgba(0, 0, 0, 0.048), 0 12.5px 10px rgba(0, 0, 0, 0.06), 0 22.3px 17.9px rgba(0, 0, 0, 0.072), 0 41.8px 33.4px rgba(0, 0, 0, 0.086), 0 100px 80px rgba(0, 0, 0, 0.12); } #proactive-chat-dialog .chatContainer .chat-cta { text-align: center; font-size: 24px; font-weight: 600; position: relative; top: 160px; } #proactive-chat-dialog .chatContainer .chat-buttons { position: relative; top: 185px; width: 100%; display: flex; gap: 1em; justify-content: center; flex-direction: column; } #proactive-chat-dialog .chatContainer .chat-buttons .arrow-link { width: auto; margin: auto; } #proactive-chat-dialog .chatContainer .chat-buttons .arrow-link:after { bottom: -6px; } @media only screen and (min-width: 33.75em) { #proactive-chat-dialog .chatContainer .chat-buttons { top: 200px; flex-direction: row; } } </style> <div id="proactive-chat-dialog" class="proactive-chat-hidden"> <div class="chatContainer" style="background: url('{{module.bg-img-src}}') no-repeat top left" > <div class="chat-cta">{{module.heading}}</div> <div class="chat-buttons"> <button type="button" id="chatEngagement" aria-label="{{chat-engagement.aria-label}}" class="button button--primary01 lp-chatnow" data-lp-event="click" data-bi-id="expand-chat" data-bi-an="chat" data-bi-chtid="azure chat 1" data-bi-chtnm="live person proactive chat" data-bi-bhvr="16" data-bi-tn="button button--primary01 lp-chatnow" > {{chat-engagement.btn-txt}} </button> <button type="button" id="chatDisengagement" aria-label="{{chat-disengagement.aria-label}}" class="arrow-link lp-nothanks" data-lp-event="close" data-bi-id="collapse-chat" data-bi-an="chat" data-bi-chtid="azure chat 1" data-bi-chtnm="live person proactive chat" data-bi-tn="arrow-link lp-nothanks" > {{chat-disengagement.btn-txt}} </button> </div> </div> </div> '/>