-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSqlServerClone.ps1
136 lines (115 loc) · 6.49 KB
/
SqlServerClone.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
$SolutionPrefix = "ttvdtrn"
$AzureSubscriptionName = "Microsoft Azure"
$ResourceGroupLocation = "westeurope"
$VirtualMachineSize = "Standard_DS12_v2"
$adminPasswordSec = Read-host "Admin and SQL password?" -AsSecureString
$adminPasswordBSTR = [System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($adminPasswordSec)
$adminPassword = [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($adminPasswordBSTR)
$numVmcopies = Read-host "Number of copies to be created?"
$SourceResourceGroupName = ($SolutionPrefix + "resg001")
$DestResourceGroupName = ($SolutionPrefix + "resg002")
$TemplateParameters = @{
numberOfVms = [convert]::ToInt32($numVmcopies)
destResourceGroupName = $DestResourceGroupName
sourceResourceGroupName = $SourceResourceGroupName
adminPassword = $adminPassword
sqlAuthenticationPassword = $adminPassword
location = $ResourceGroupLocation
virtualMachineName = $SolutionPrefix + "vser"
adminUsername = $SolutionPrefix + "admin"
virtualNetworkName = $SolutionPrefix + "vnet001"
networkInterfaceName = $SolutionPrefix + "vnic"
storageAccountName = $SolutionPrefix + "stac001"
diagnosticsStorageAccountName = $SolutionPrefix + "stac002"
subnetName = $SolutionPrefix + "snet001managementServices"
publicIpAddressName = $SolutionPrefix + "vipi"
sqlAuthenticationLogin = $SolutionPrefix + "admin"
virtualMachineSize = $VirtualMachineSize
storageAccountType = "Premium_LRS"
diagnosticsStorageAccountType = "Standard_LRS"
diagnosticsStorageAccountId = "Microsoft.Storage/storageAccounts/" + $SolutionPrefix + "stac002"
publicIpAddressType = "Dynamic"
sqlConnectivityType = "Private"
sqlPortNumber = 1433
sqlStorageDisksCount = 1
sqlStorageWorkloadType = "GENERAL"
sqlStorageDisksConfigurationType = "NEW"
sqlStorageStartingDeviceId = 2
sqlStorageDeploymentToken = 16335
sqlAutopatchingDayOfWeek = "Sunday"
sqlAutopatchingStartHour = "2"
sqlAutopatchingWindowDuration = "60"
rServicesEnabled = "true"
osDiskUri = "LaterConfigured"
dataDiskUri = "LaterConfigured"
}
$TemplateFileUri = "https://raw.githubusercontent.com/TVDKoni/ARM-Base-Templates/master/SqlServerClone/sqlServerCloneDeployment.json"
function New-TemporaryDirectory
{
$path = Join-Path ([System.IO.Path]::GetTempPath()) ([System.IO.Path]::GetRandomFileName())
while(Test-Path $path) {
$path = Join-Path ([System.IO.Path]::GetTempPath()) ([System.IO.Path]::GetRandomFileName())
}
New-Item -ItemType Directory -Path $path
}
Write-Host "Please prepare first the source image like described in:"
Write-Host "https://raw.githubusercontent.com/TVDKoni/ARM-Base-Templates/master/SqlServerClone/PrepareVmImage.pdf"
Write-Host ' - Run command: & "$Env:SystemRoot\system32\sysprep\sysprep.exe" /generalize /oobe /shutdown'
Write-Host ' - Wait until the vm has stopped state'
pause
Write-Host "Login to azure account"
Login-AzureRmAccount
Write-Host "Selecting subscription '$($AzureSubscriptionName)'"
$subscription = Get-AzureRmSubscription –SubscriptionName $AzureSubscriptionName #add -TenantId if subscription name is not unique
Select-AzureRmSubscription -SubscriptionId $subscription.SubscriptionId | Out-String | Write-Verbose
Write-Host "Getting resource group '$($DestResourceGroupName)'"
if (-not (Get-AzureRmResourceGroup -Name $DestResourceGroupName -Location $ResourceGroupLocation -ErrorAction SilentlyContinue)) {
Write-Host "Resource group does not exists. Creating it."
New-AzureRmResourceGroup -Name $DestResourceGroupName -Location $ResourceGroupLocation | Out-String | Write-Verbose
}
Write-Host "Preparing the source vm '$($SolutionPrefix)vser001'"
Stop-AzureRmVM -ResourceGroupName $SourceResourceGroupName -Name ($SolutionPrefix + "vser001") -Force
Set-AzureRmVM -ResourceGroupName $SourceResourceGroupName -Name ($SolutionPrefix + "vser001") -Generalized
$tempdir = New-TemporaryDirectory
$tempfile = $tempdir.FullName + "\Template.json"
Write-Host "Saving the source vm '$($SolutionPrefix)vser001' as template to $($tempfile)"
Save-AzureRmVMImage -ResourceGroupName $SourceResourceGroupName -VMName ($SolutionPrefix + "vser001") -DestinationContainerName 'templates' -VHDNamePrefix 'template' -Path $tempfile
Write-Host "Reading template"
$template = (Get-Content $tempfile) -join "`n" | ConvertFrom-Json
$storageProfile = $template.resources[0].properties.storageProfile
$TemplateParameters.osDiskUri = $storageProfile.osDisk.image.uri
$TemplateParameters.dataDiskUri = $storageProfile.dataDisks[0].image.uri
<#
$RecreateTemplateParameters = $TemplateParameters.PsObject.Copy()
$RecreateTemplateParameters.osDiskUri = $storageProfile.osDisk.image.uri
$RecreateTemplateParameters.dataDiskUri = $storageProfile.dataDisks[0].image.uri
$RecreateTemplateParameters.destResourceGroupName = $SourceResourceGroupName
$RecreateTemplateParameters.virtualMachineName = $SolutionPrefix + "vser001"
$RecreateTemplateParameters.networkInterfaceName = $SolutionPrefix + "vser001nic"
$RecreateTemplateParameters.publicIpAddressName = $SolutionPrefix + "vser001pip"
$RecreateTemplateParameters.Remove("sourceResourceGroupName")
$RecreateTemplateParameters.Remove("numberOfVms")
$RecreateTemplateFileUri = "https://raw.githubusercontent.com/TVDKoni/ARM-Base-Templates/master/SqlServer/sqlServerDeploymentRecreate.json"
Write-Host "Deleting master VM"
Remove-AzureRmVM -ResourceGroupName $SourceResourceGroupName -Name ($SolutionPrefix + "vser001") -Force
$StAccountKey = Get-AzureRmStorageAccountKey -ResourceGroupName $SourceResourceGroupName -AccountName $TemplateParameters.storageAccountName -ErrorAction SilentlyContinue
$StContext = New-AzureStorageContext -StorageAccountName $TemplateParameters.storageAccountName -StorageAccountKey $StAccountKey.Key1
$StContainer = Get-AzureStorageContainer -Context $StContext -Name "vhds"
$StContainer | Get-AzureStorageBlob | foreach {
if ($_.Name -contains ($SolutionPrefix + "vser001"))
{
$_.ICloudBlob.Delete()
}
}
Write-Host "Recreating master VM"
$deployment = New-AzureRmResourceGroupDeployment -ResourceGroupName $SourceResourceGroupName -TemplateUri $RecreateTemplateFileUri -TemplateParameterObject $RecreateTemplateParameters -Verbose
#>
Write-Host "Deploying clones"
$deployment = New-AzureRmResourceGroupDeployment -ResourceGroupName $DestResourceGroupName -TemplateUri $TemplateFileUri -TemplateParameterObject $TemplateParameters -Verbose
Write-Host "Template outputs:"
foreach($key in $deployment.Outputs.Keys)
{
Write-Host (" " + $key + ": " + $deployment.Outputs[$key].Value)
}
Write-Host "Done"
pause