-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathDatabaseBACPAC_Export.ps1
60 lines (53 loc) · 1.85 KB
/
DatabaseBACPAC_Export.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
Import-Module Az.KeyVault
Import-Module Az.Sql
Import-Module Az.Accounts
$connectionName = "AzureRunAsConnection"
try
{
# Get the connection "AzureRunAsConnection "
$servicePrincipalConnection = Get-AutomationConnection -Name $connectionName
"Logging in to Azure..."
Connect-AzAccount `
-ServicePrincipal `
-TenantId $servicePrincipalConnection.TenantId `
-ApplicationId $servicePrincipalConnection.ApplicationId `
-CertificateThumbprint $servicePrincipalConnection.CertificateThumbprint
}
catch {
if (!$servicePrincipalConnection)
{
$ErrorMessage = "Connection $connectionName not found."
throw $ErrorMessage
} else{
Write-Error -Message $_.Exception
throw $_.Exception
}
}
try
{
$RG = ""
$Server = ""
$DB = ""
$StorageKey = Get-AutomationVariable -Name ""
$User = ""
$Pass = Get-AutomationVariable -Name ""
$Password = ConvertTo-SecureString $Pass -AsPlainText -Force
$BackupPath = $DB + (Get-Date).ToString("yyyy-MM-dd")
$StorageUri = "https://######.blob.core.windows.net/deploymentbackups/$BackupPath.bacpac"
$backupjob = New-AzSqlDatabaseExport -ResourceGroupName $RG -ServerName $Server -DatabaseName $DB -StorageKeyType "StorageAccessKey" -StorageKey $StorageKey -StorageUri $StorageUri -AuthenticationType "AdPassword" -AdministratorLogin $User -AdministratorLoginPassword $Password
Write-Output $backupjob
$jobstatus = Get-AzSqlDatabaseImportExportStatus -OperationStatusLink $backupjob.OperationStatusLink
Write-Output "Start of database backup"
while ($jobstatus.Status -eq "InProgress"){
$jobstatus = Get-AzSqlDatabaseImportExportStatus -OperationStatusLink $backupjob.OperationStatusLink
$jobstatus.Status
Start-Sleep -s 15
}
Write-Output "Database backup completed"
}
catch
{
$message = $_.Exception.Message
Write-Output $message
throw $message
}