Table of Contents
Introduction
Today, I’m going to show you how to schedule the restart/pause/start of your Azure Synapse Analytics database. You will use an Azure Automation Account and Runbooks.
In my previous blog post, you were able to use a PowerShell to restart Azure Synapse Analytics, but today we’ll use Azure Automation Accounts and Runbooks to schedule this activity.
Create an Azure Automation Account
To begin, automation accounts allow you to automate maintenance activities within the Azure environment. Hardcoding credentials within external PowerShell scripts aren’t necessary.
First, let’s create one.
data:image/s3,"s3://crabby-images/98f8c/98f8c77529d0a957b5b1934c58789d279f7ef343" alt="Create an automation account Create an automation account"
Next, once you find the service, select “Add” to create a new one.
data:image/s3,"s3://crabby-images/9f6ed/9f6eddaf611fdc04683ca9417ee0ad5040bf6e24" alt="Click add to create an automation account"
The configuration isn’t very complex, but you want to select the option for the service to create the Run As account for you as well. This we you don’t need to do it manually.
data:image/s3,"s3://crabby-images/eaa18/eaa18752b49864452f172ece8f8bc20a16871c1b" alt="Create Azure Run As account Create Azure Run As account"
Once the creation has finished, the service will show different options.
data:image/s3,"s3://crabby-images/e4a81/e4a81998aff67199b0e22e139c43e9a7d94e564c" alt="Options for service"
Next up, create a Runbook.
Configure Automation Account
For your PowerShell script, use the new Az modules to manage the Azure environment. You need 2 different modules:
- Az.Accounts
- Az.Sql
You can also install “Az” because it includes all the modules, but I recommend only installing what is required. In this way, you can learn about the different modules without adding too much overhead to the Runbook.
Install Az.Accounts module
You can easily find the module in the gallery.
data:image/s3,"s3://crabby-images/cf1ed/cf1ed2bfd2cfb6d7cc0dd773a539c52370d6be69" alt="Install Az.Accounts module Install Az.Accounts module"
Then, import the Az.Accounts module.
data:image/s3,"s3://crabby-images/71d7a/71d7a09a601a6666670878ce27aba66e483932e0" alt="Import the Az.Accounts module"
data:image/s3,"s3://crabby-images/385f4/385f421a39e64264914c7b60e7bd5b1ab3afea3c" alt="Import screen"
Importing the module takes a few minutes.
data:image/s3,"s3://crabby-images/b126d/b126de119a15db43d0f7017ec63587bb2835b184" alt="Az.Accounts module imported"
data:image/s3,"s3://crabby-images/c035c/c035c9ad7ec05c9f6ca1dad0a8a612c56d82871e" alt="Available"
Now, repeat the same process for the Az.Sql module.
Install Az.Sql module
data:image/s3,"s3://crabby-images/17243/17243270d957cc714dc784e5dfdf3461a79e4d81" alt="Install Az.Sql module Install Az.Sql module"
data:image/s3,"s3://crabby-images/a9ea1/a9ea12b0a4f722af486a577dacae0d6a1ff1f715" alt="Click import"
data:image/s3,"s3://crabby-images/a57ac/a57accc6ad6417bfb56a186e8a6701beae0e8d3e" alt="Importing Az.Sql"
Do you remember the option that you selected to create the Run-As-Account automatically? You can see it in the following sections.
data:image/s3,"s3://crabby-images/2c143/2c14318561eb18f1f0054d7dfe5f2e66d716db1c" alt="Azure Run As Connection Azure Run As Connection"
It also includes giving Contributor at the Subscription level. If you want to further lock down access , you can create the account manually and give access to different services.
data:image/s3,"s3://crabby-images/b5040/b50401fad4b5f722123474d31fdecadd40de3fe6" alt="Run as accounts"
Create Runbook
Runbooks are the activities that you can execute as part of a routine. In this example, it’s Restarting Azure Synapse Analytics SQL Pools.
data:image/s3,"s3://crabby-images/1b8c4/1b8c4e8f4281fedc43d9b41b6f39f4ec9793748e" alt="Create Runbook Create Runbook"
By default, your Azure Automation Account includes some Runbooks.
Select “Create a runbook”
data:image/s3,"s3://crabby-images/58592/585925f0b378d8ab2f9b8f2763cba72f633c958e" alt="Click create a runbook"
Then, include a name and description.
Page Break
data:image/s3,"s3://crabby-images/bbab5/bbab539cd6e7366007bd368f176e88e56ea2a196" alt="Include a name and description"
Now you are ready to include the logic in the script.
Include Script and Schedule Restart
You can download the PowerShell script that you need to copy from:
You will need to paste the scrip in the editor.
data:image/s3,"s3://crabby-images/21452/214523ea8d3873b7dbbb42fced46db1ee2906013" alt="PowerShell Runbook script PowerShell Runbook script"
Uncomment the following lines.
data:image/s3,"s3://crabby-images/cf785/cf78582dbcd654894281cc693a061cf430779343" alt=""
So it looks like the following picture.
data:image/s3,"s3://crabby-images/a8c7a/a8c7aeb32164e5771459bb7c3e098753d6ea3d63" alt=""
By using the Test Pane, it’s possible to debug the script before publishing it.
Next, publish the script.
data:image/s3,"s3://crabby-images/6f8ae/6f8ae6d72e0d08cedb939f2d3722dc928d3874e8" alt="Publish the script"
Now, let’s run it manually.
data:image/s3,"s3://crabby-images/75efc/75efcf45cb12864efcb9158c8b7205d2aa14e71f" alt="Start the Runbook"
Include the parameter values.
data:image/s3,"s3://crabby-images/094ed/094ed4077e6a5518fd6708be4a5716399bfdd50b" alt="Include parameter values in Runbook Include parameter values in Runbook"
A new window will open with the execution status.
data:image/s3,"s3://crabby-images/0a070/0a070548f4df5c6e239aff3ec328697fc2376a40" alt="Execution status"
You can see the output here.
data:image/s3,"s3://crabby-images/85c8c/85c8c6d8057521f499e14d98bdaa82d041a68f58" alt=""
As you can see, the Synapse Analytics has restarted (pause/start).
data:image/s3,"s3://crabby-images/6c4a6/6c4a6bcbf8cd3cb3a7c244955303e9fc49c0be8e" alt=""
Schedule Runbook
You can attach your runbook to a schedule by using the following option.
data:image/s3,"s3://crabby-images/5b4d3/5b4d308d1094ec1f4c17a75523c7dab5e3c7741e" alt=""
You can create one by following the next options.
data:image/s3,"s3://crabby-images/5a8a3/5a8a39f1a946eb2be141a51b2441958262797d82" alt=""
Defining the time zone is one of the options within the schedule.
data:image/s3,"s3://crabby-images/c7ae6/c7ae67a3b61a28ed8da97ab810ee1fb7044c17a1" alt=""
And you can finally define the parameters. The same script will allow you to use the operations Pause and Start separately.
data:image/s3,"s3://crabby-images/389c9/389c9ce093d3da1d85fca0e2703f5985cc42d4c7" alt=""
Now, you can save the schedule
data:image/s3,"s3://crabby-images/89283/89283b33e5a645bd7ae5959e38d4b316b2fac53d" alt=""
Verifying the schedule.
data:image/s3,"s3://crabby-images/b82dc/b82dcd8cebaf60c0e3e65dbbe22cfea906400979" alt=""
And you are all set!
The next schedule will kick off the restart operation.
data:image/s3,"s3://crabby-images/18589/1858952943a68e3c0837b6a02a83362a1c5e5b6a" alt=""
Summary
In summary, by following the steps above, you can schedule the restart of your Azure Synapse Analytics SQL Pool on a different time basis using Automation Accounts and Runbooks.
Final Thoughts
Finally, Azure Automation Accounts and Runbooks are useful to schedule routines for maintenance activities. Not only can you manage Azure Synapse Analytics, but it’s also possible to manage all your Azure services.
What’s Next?
In upcoming blog posts, we’ll continue to explore some of the features within Azure Services.
Please follow Tech Talk Corner on Twitter for blog updates, virtual presentations, and more!
As always, please leave any comments or questions below.
1 Response
angry_dba
30 . 11 . 2022Hi David,
Have you been able to get this work for the “new” version of Synapse where the resources are in a Microsoft managed RG? There are explicit DENY permissions on this Microsoft managed RG (where the SQL pool and logical SQL server are located) that prevent a runbook from performing any actions on it.
Example error:
DenyAssignmentAuthorizationFailed: The client ‘4a6ac1a9-2f2a-471b-830a-783e5db81de3’ with object id ‘4a6ac1a9-2f2a-471b-830a-783e5db81de3’ has permission to perform action ‘Microsoft.Sql/servers/databases/pause/action’ on scope ‘/subscriptions//resourceGroups/-rg/providers/Microsoft.Sql/servers//databases/synapsesqlpool’;
however, the access is denied because of the deny assignment with name ’15e94f5e-5096-4475-9201-c5d33f8d72be’ and Id ’15e94f5e509644759201c5d33f8d72be’ at scope ‘/subscriptions//resourceGroups/’.