How to mount storage in Azure Containers
Guide to Setting Up a File Share for Your Azure Container App
In this tutorial, we will guide you through the process of setting up an Azure file share and binding it to a container environment. This setup is essential for providing persistent storage that your container app can access.
Here is a link to the docker files if you wanted to see the Dockerfile or .py script.
Step 1: Create a File Share in Azure Storage
- Open the Storage Account
- Navigate to your Azure storage account.
- Go to Storage Browser > File Shares.
- Add a File Share
- Click Add File Share.
- Name your file share anything you’d like. We will reference this name later in the container environment.
- For this guide, we will use the name
'containerappfilestorage'
.
data:image/s3,"s3://crabby-images/a5dea/a5deadf5f04fa61311f0310e0c9dec329b943e7b" alt="This image shows where to create a file share in azure storage"
data:image/s3,"s3://crabby-images/cd454/cd454e43c3952442385a17637b5017b2ee3edfa6" alt="This image shows the file share I created for this tutorial. The name is important later!"
Step 2: Bind the File Share to the Container Environment
- Open the Container App Environment
- In the Azure portal, navigate to your Container App Environment.
- Go to Azure Files > Add > SMB File Share.
- Fill in the Required Information:
- Name: You can give it any name you want.
- Storage Account Name: Enter the name of your storage account.
- Storage Account Key: This can be found in your storage account under Access Keys. Make sure to copy the Key and not the connection string.
- File Share Name: Enter the name of the file share you created earlier (in our case,
containerappfilestorage
). - Access Mode: For this tutorial, set the access mode to Read/Write. Note that for some applications, Read-only access is recommended to ensure stability, especially if the app crashes or is interrupted during file writing, which can lead to file corruption.
- Add the File Share
- Once all the information is entered, click Add to bind the file share to the environment.
- Don’t forget to save the file share to the environment!
data:image/s3,"s3://crabby-images/533dd/533dde6426d777b13c3c31f0a3d16a9f6dac407f" alt="This shows were to add Azure Files Storage in the Container App Environment."
data:image/s3,"s3://crabby-images/73b96/73b9659a89ef29ea653bb63002d7fdcee0cdf7d1" alt="This image shows the Add SMB file share prompt."
data:image/s3,"s3://crabby-images/f3516/f35167c31138d8c381a35afa505e7f6ceaf7b459" alt="This image shows where the access keys are located in your storage account."
Step 3: Attach the File Share to Your Container App
- Open Your Container App
- Navigate to the container app you want to bind the file share to.
- Create a Volume
- Go to Volumes > Add.
- Select the file share you just added to the environment.
- Click Add and then Save as a new revision.
data:image/s3,"s3://crabby-images/a9ac9/a9ac958878ffc86d02366bff8d420c2455ddead4" alt="This image shows how to mount the SMB share as a volume in you container app."
Step 4: Bind the File Share to Your Container
- Create a New Revision for the Container
- Navigate to Revisions and Replicas.
- Click Create a new revision.
- Add a New App Container
- Configure the Docker image for your container.
- Name: Choose a label for your container (this can be whatever you prefer).
- Image Source: Select Docker Hub.
- Image Type: Set this to Public.
- Login Server: Set this to
docker.io
. - Image and Tag: For this tutorial, we’ll be using the image
icefire555/azuredatatest:latest
, but you can use your own Docker image.
- Configure Volume Mounts
- Go to the Volume Mounts tab.
- Select the storage name from the volume you just added.
- Set a mount path. For this guide, we’ll use
/data
.
- Save and Deploy
- Save the container and click Create to start the deployment.
data:image/s3,"s3://crabby-images/7d034/7d034f6d94ad591c47eb71cd37e3e4cb6a7e6a2f" alt="This image shows you how do create a new revision so we can configure our docker image to be pulled."
data:image/s3,"s3://crabby-images/38534/38534cc07aee284cdc7fbc5becdbfda6d1c3fbf9" alt="This image shows how to create a new app container."
data:image/s3,"s3://crabby-images/3a1da/3a1dad8544463e8981c2c237771e8608c3e4b4f7" alt="This image shows the settings used to pull a docker image from Docket Hub."
data:image/s3,"s3://crabby-images/ba3e9/ba3e9d30e3ed83ee9e5dec88ada25e26754e183f" alt="This image shows how to mount the volume to your container."
Step 5: Monitor Your Container’s Logs
- View the Console Logs
- After deployment, select your revision and open the Console Logs to monitor the container’s performance.
- Storage Access
- If the container has already run, you can view the output file in the Storage Browser of your Azure storage account.
data:image/s3,"s3://crabby-images/65dd4/65dd4e0102add303aa1436c4add8e59df73f0814" alt="This image shows how to check your container logs."
data:image/s3,"s3://crabby-images/112d1/112d157bf9214249f1a1a19cb149cabe403216b8" alt="This image shows what the output will look like on the first run."
data:image/s3,"s3://crabby-images/c6a6e/c6a6e6c4ede1fde11f03f691934327b58a7c0854" alt="This image shows what the output will look like on future runs."
data:image/s3,"s3://crabby-images/e974d/e974d6f89a74bd1acd50b718a04d45d5a6d85053" alt="This image shows the file the code created in the file share."
By following these steps, you should now have a fully configured Azure file share bound to your container app, ready for deployment and use. Feel free to modify these instructions to suit your specific application needs!