data:image/s3,"s3://crabby-images/5ff76/5ff7614ba7a1c7b499bda8bae56c806789c44b25" alt="How to backup your database to a storage account using a managed identity ?"
How to backup your database to a storage account using a managed identity ?
What if I told you that we can export your database to a storage account, automatically using a managed identity ? the rest is just below
Prerequisites
You will need:
- SQL Database
- Automation Account
- My Github : -azure-backupsqldatabase/Export DB PAAS By Automation Account.ps1 at main · technicalandcloud/-azure-backupsqldatabase (github.com)
- One Managed Identity ( System or User) – Contributor Role
In Storage Account, enable « Allow Azure services and resources to access this server« :
data:image/s3,"s3://crabby-images/69842/6984241182393673b885cd2ae7f7af61c1dffb18" alt=""
Deployment
First step, we will create our Managed Identity.
Go to Managed Identities and click on Create:
data:image/s3,"s3://crabby-images/46658/46658a89c458e8bb490286dd4bc5139c4f8c382e" alt=""
Fill in the requested fields.
Once the identity is created, go to Azure Role Assignments:
data:image/s3,"s3://crabby-images/b547d/b547de3a151a0e16ba6f05b6714fe306f768d9fc" alt=""
and apply the Contributor role to it:
data:image/s3,"s3://crabby-images/6100d/6100d353d4461aaa66b5ca42600e5ce9665df681" alt=""
Then go to Automation Account in Identity and select User assigned and click Add to add your previously created Identity:
data:image/s3,"s3://crabby-images/b6869/b686950d1327c14758c744b6a81df82e1f5c9bc2" alt=""
Once finished, go to my github page:
Retrieve the Code and put it in a Runbook:
Remember to change the client ID of your Managed Identities:
data:image/s3,"s3://crabby-images/a8877/a887787a4fc994bff5b059049164dddc9d502e4b" alt=""
Once finished, we can save and launch the execution:
data:image/s3,"s3://crabby-images/b7ddd/b7dddb6cdec48d731f09e66c592732931aef254c" alt=""
Fill in the different fields mentioned on the right:
data:image/s3,"s3://crabby-images/080f7/080f7bedc83fc0da415a5f31653c274f469093b9" alt=""
Once completed and launched, we can return to the SQL Server, we see an export in progress :
data:image/s3,"s3://crabby-images/d61d8/d61d853f7b9d972e2d5e13af19d3f3578715ef74" alt=""
If we go back to our storage account, we can see our .BACPAC file in our container:
data:image/s3,"s3://crabby-images/26c4e/26c4e239bec559b52975be9bbd4eeec2a986db95" alt=""
Then, we can go to automation account -> Schedule, to automate the export:
data:image/s3,"s3://crabby-images/73524/7352403b8941d5956615e856685c659ee9e3ae17" alt=""
Conclusion
Now you know How to backup your database to a storage account using a managed identity, and you can make the export automatic.