About Me

My photo
HANUMANGARH, RAJASTHAN, India

Friday, 8 January 2021

Add Custom Script Extension on multiple Azure VMs

 

How it works?

First of all you must have a script which you want to run on all of yours Azure virtual machines. In my case it was script for FTP installation on IIS – but for you it can be for example on creation of local user of group on machine. Once you have a script you should copy it as a blob to storage account. Once it is done you should provide proper input parameters to script, limit the scope of virtual machines to which it should apply (line 12 of a script) and this is the way to add custom script extension to multiple machines on Azure.


IMPORTANT:

You should keep in mind that script will remove custom script extension if it’s already exist on machine. It will not destroy changes applied by this script, but only extension itself. The reason of that is the Azure VMs do not support more than one same type of extension installed.

Requirements:

  • Az module installed
  • Proper access to subscription where you have storage account and virtual machines – best Contributor

Script:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
param(
    $TenantId,
    $defaultSubscriptionId,
    $customScriptExtensionName,
    $scriptName,
    $storageAccountName,
    $storageAccountContainer,
    $storageAccountResourceGroup,
    $storageSubscriptionId
)
 
$VMs = Get-AzVM ## Here you should apply filter if you want to limit installation to specific VMs
 
Select-AzSubscription -SubscriptionId $storageSubscriptionId
 
$fileUri = @("https://$storageAccountName.blob.core.windows.net/$storageAccountContainer/$scriptName")
$settings = @{"fileUris" = $fileUri};
$storageKey = (Get-AzStorageAccountKey -Name $storageAccountName -ResourceGroupName $storageAccountResourceGroup)[0].Value
$protectedSettings = @{"storageAccountName" = $storageAccounttName; "storageAccountKey" = $storageKey; "commandToExecute" = "powershell -ExecutionPolicy Unrestricted -File $scriptName"};
 
Select-AzSubscription -SubscriptionId $defaultSubscriptionId
 
foreach($vm in $VMs){
    Write-Output "Starting VM $($vm.Name)"
    Start-AzVm -ResourceGroupName "$($vm.ResourceGroupName)" -Name "$($vm.Name)"
    Write-OUtput "Working on vm $($vm.Name)"
    $extensions = (Get-AzVm -ResourceGroupName "$($vm.ResourceGroupName)" -Name "$($vm.Name)").Extensions
    foreach($ext in $extensions)
    {
        if($ext.VirtualMachineExtensionType -eq "CustomScriptExtension"){
            Write-Output "Removing CustomScriptExtension with name $($ext.Name) from vm $($vm.Name)"
            Remove-AzVMExtension -ResourceGroupName "$($vm.ResourceGroupName)" -VMName "$($vm.Name)" -Name $ext.Name -Force
            Write-Output "Removed CustomScriptExtension with name $($ext.Name) from vm $($vm.Name)"
        }
    }
    Write-Output "$customScriptExtenstionName installation on VM $($vm.Name)"
 
    Set-AzVMExtension -ResourceGroupName "$($vm.ResourceGroupName)" `
        -Location "$($vm.Location)" `
        -VMName "$($vm.Name)" `
        -Name "$customScriptExtenstionName" `
        -Publisher "Microsoft.Compute" `
        -ExtensionType "CustomScriptExtension" `
        -TypeHandlerVersion "1.10" `    `
        -Settings $settings    `
        -ProtectedSettings $protectedSettings
 
    Write-Output "---------------------------"
}

No comments:

Post a Comment

Export contact from Justdial

  Extract Data From JustDial using Selenium Let us see how to extract data from Justdial using Selenium and Python. Justdial is a company th...