forked from JeffBow/AzurePowerShell
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathStart-AzureV2VM.ps1
214 lines (158 loc) · 6.31 KB
/
Start-AzureV2VM.ps1
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
<#
.SYNOPSIS
Starts all Azure V2 (ARM) virtual machines by resource group.
.DESCRIPTION
Uses PowerShell workflow to start all VMs in parallel. Includes a retry and wait cycle to display when VMs are started.
Workflow sessions require Azure authentication into each session so this script uses a splatting of parameters required for Connect-AzureRmAccount that
can be passed to each session. Recommend using the New-AzureServicePrincipal script to create the required service principal and associated ApplicationId
and certificate thumbprint required to log into Azure with the -servicePrincipal flag
.EXAMPLE
.\Start-AzureV2vm.ps1 -ResourceGroupName 'CONTOSO' -CertificateThumbprint 'F3FB843E7D22594E16066F1A3A04CA29D5D6DA91' -ApplicationID 'd2d20159-4482-4987-9724-f367afb170e8' -TenantID '72f632bf-86f6-41af-77ab-2d7cd011db47'
.EXAMPLE
.\Start-AzureV2vm.ps1 -FirstServer 'DC-CONTOSO-01' -ResourceGroupName 'CONTOSO' -CertificateThumbprint 'F3FB843E7D22594E16066F1A3A04CA29D5D6DA91' -ApplicationID 'd2d20159-4482-4987-9724-f367afb170e8' -TenantID '72f632bf-86f6-41af-77ab-2d7cd011db47'
.PARAMETER -ResourceGroupName [string]
Name of resource group being copied
.PARAMETER -CertificateThumbprint [string]
Thumbprint of the x509 certificate that is used for authentication
.PARAMETER -ApplicationId [string]
Aplication ID of the registered Azure Active Directory Service Principal
.PARAMETER -TenantId [string]
Tenant ID of the registered Azure Active Directory Service Principal
.PARAMETER -Environment [string]
Name of Environment e.g. AzureUSGovernment. Defaults to AzureCloud
.PARAMETER -FirstServer [string]
Identifies the the first server to start. i.e. a domain controller
.NOTES
Original Author: https://github.com/JeffBow
------------------------------------------------------------------------
Copyright (C) 2016 Microsoft Corporation
You have a royalty-free right to use, modify, reproduce and distribute
this sample script (and/or any modified version) in any way
you find useful, provided that you agree that Microsoft has no warranty,
obligations or liability for any sample application or script files.
------------------------------------------------------------------------
#>
#Requires -Version 4.0
#Requires -Module AzureRM.Profile
#Requires -Module AzureRM.Resources
#Requires -Module AzureRM.Storage
#Requires -Module AzureRM.Compute
param(
[Parameter(Mandatory=$true)]
[string]$ResourceGroupName,
[Parameter(Mandatory=$true)]
[string]$CertificateThumbprint,
[Parameter(Mandatory=$true)]
[string]$ApplicationId,
[Parameter(Mandatory=$true)]
[string]$TenantId,
[Parameter(Mandatory=$false)]
[string]$Environment= "AzureCloud",
[Parameter(Mandatory=$false)]
[string]$FirstServer
)
$loginParams = @{
"CertificateThumbprint" = $CertificateThumbprint
"ApplicationId" = $ApplicationId
"TenantId" = $TenantId
"ServicePrincipal" = $null
"EnvironmentName" = $Environment
}
$ProgressPreference = 'SilentlyContinue'
import-module AzureRM
if ((Get-Module AzureRM).Version -lt "5.5.0") {
Write-warning "Old version of Azure PowerShell module $((Get-Module AzureRM).Version.ToString()) detected. Minimum of 5.5.0 required. Run Update-Module AzureRM"
BREAK
}
function Start-Vm
{
param($vmName, $resourceGroupName)
Write-Output "Starting $vmName..."
$count=1
do
{
$status = ((get-azurermvm -ResourceGroupName $resourceGroupName -Name $vmName -status).Statuses|where{$_.Code -like 'PowerState*'}).DisplayStatus
Write-Output "$vmName current status is $status"
if($status -ne 'VM running')
{
if($count -gt 1)
{
Write-Output "Failed to start $VMName. Retrying in 60 seconds..."
sleep 60
}
$rtn = Start-AzureRMVM -Name $VMName -ResourceGroupName $ResourceGroupName -ea SilentlyContinue
$count++
}
}
while($status -ne 'VM running' -and $count -lt 5)
if($status -eq 'VM running')
{
Write-Output "$VMName started."
}
else
{
Write-Output "Startup of $VMName FAILED on attempt number $count of 5."
}
} # end of start-vm function
Workflow Start-VMs
{ param($VMs, $ResourceGroupName, $loginParams)
foreach -parallel ($vm in $VMs)
{
$login = Connect-AzureRmAccount @loginParams
$vmName = $vm.Name
Start-Vm -VmName $vmName -ResourceGroupName $resourceGroupName
}
} # end of worflow
# Connect to Azure and with Service Principal
try
{
# Log into Azure
Connect-AzureRmAccount @loginParams -ea Stop | out-null
}
catch
{
if (! $CertificateThumbprint)
{
$ErrorMessage = "Certificate $CertificateThumbprint not found."
throw $ErrorMessage
}
else
{
Write-Error -Message $_.Exception
throw $_.Exception
}
BREAK
}
$vms = Get-AzureRmVM -ResourceGroupName $ResourceGroupName
#pre action confirmation
write-output "Starting...$($vms.Name)"
# start your DC or other server first
if($firstServer)
{
Start-Vm -vmName $firstServer -ResourceGroupName $resourceGroupName
sleep 10
}
# Get remaining VMs that are stopped and Start everything
$remainingVMs = $vms | where-object -FilterScript{$_.name -ne $firstServer}
Start-VMs -VMs $remainingVMs -ResourceGroupName $resourceGroupName -loginParams $loginParams
#post action confirmation
do{
cls
write-host "Waiting for VMs in $resourceGroupName to start..."
$allStatus = @()
foreach ($vm in $VMs)
{
$status = ((get-azurermvm -ResourceGroupName $resourceGroupName -Name $vm.Name -status).Statuses|where{$_.Code -like 'PowerState*'}).DisplayStatus
"$($vm.Name) - $status"
$allStatus += $status
}
sleep 3
}
while($allStatus -ne 'VM Running')
cls
write-host "All VMs in $resourceGroupName are ready..."
foreach ($vm in $VMs)
{
$status = ((get-azurermvm -ResourceGroupName $resourceGroupName -Name $vm.Name -status).Statuses|where{$_.Code -like 'PowerState*'}).DisplayStatus
"$($vm.Name) - $status"
}