Start-Stop-Automation/Automation-Backend/Runbooks/Stop-SAPSystem.ps1 (181 lines of code) (raw):
<#PSScriptInfo
.DESCRIPTION Azure Automation Runbook Script to stop an SAP system.
.VERSION 0.0.4
.GUID e67257ff-d964-4403-8e39-7a5d47f725b3
.AUTHOR Goran Condric
.COMPANYNAME Microsoft
.COPYRIGHT (c) 2020 Microsoft . All rights reserved.
.TAGS Azure Automation SAP System Stop Runbook
.LICENSEURI
.PROJECTURI
.ICONURI
.EXTERNALMODULEDEPENDENCIES SAPAzurePowerShellModules
.REQUIREDSCRIPTS
.EXTERNALSCRIPTDEPENDENCIES
.RELEASENOTES
0.0.1: - Add initial version
0.0.3: - Add dedpendencies to SAPAzurePowerShellModules module
0.0.4: - Add functionality for Java systems
#>
#Requires -Module SAPAzurePowerShellModules
Param(
[Parameter(Mandatory=$True, HelpMessage="SAP System <SID>. 3 characters , starts with letter.")]
[ValidateLength(3,3)]
[string] $SAPSID,
[Parameter(Mandatory=$False)]
[int] $SoftShutdownTimeInSeconds = "300",
[Parameter(Mandatory=$False)]
[bool] $ConvertDisksToStandard = $False,
[Parameter(Mandatory=$False)]
[bool] $PrintExecutionCommand = $False,
[Parameter(Mandatory=$false, HelpMessage="Subscription ID. If null, the current subscription of automation account is used instead.")]
[ValidateLength(36,36)]
[string] $SubscriptionId,
[Parameter(Mandatory=$False, HelpMessage="Identifier of user calling the runbook")]
[string] $User = "",
[Parameter(Mandatory=$False, HelpMessage="URL of hook, e.g. logicApp with SAS token")]
[string] $PostProcessingHook = ""
)
try {
# Deprecated due to using System Managed Identity
#$connection = Get-AutomationConnection -Name AzureRunAsConnection
#Add-AzAccount -ServicePrincipal -Tenant $connection.TenantID -ApplicationId $connection.ApplicationID -CertificateThumbprint $connection.CertificateThumbprint
# Connect to Azure with Automation Account system-assigned managed identity
# Ensure that you do not inherit an AZ Context in your runbook
Disable-AzContextAutosave -Scope Process | out-null
# Connect using Managed Service Identity
try {
$AzureContext = (Connect-AzAccount -Identity -WarningAction Ignore).context
}
catch{
Write-Output "There is no system-assigned user identity. Aborting.";
Write-Error $_.Exception.Message
exit
}
if ($SubscriptionId){
$SubscriptionId = $SubscriptionId.trim()
Select-AzSubscription -SubscriptionId $SubscriptionId -ErrorVariable -notPresent -ErrorAction SilentlyContinue -Tenant $AzureContext.Tenant
}
# get start time
$StartTime = Get-Date
$SAPSID = $SAPSID.Trim()
# Connect to Azure
$connection = Get-AutomationConnection -Name AzureRunAsConnection
Add-AzAccount -ServicePrincipal -Tenant $connection.TenantID -ApplicationId $connection.ApplicationID -CertificateThumbprint $connection.CertificateThumbprint
# get start time
$StartTime = Get-Date
$SAPSID = $SAPSID.Trim()
#Test if Tag 'SAPSystemSID' with value $SAPSID exist. If not exit
Test-AzSAPSIDTagExist -SAPSID $SAPSID
# Get SAP Appplication VMs
$SAPSIDApplicationVMs = Get-AzSAPApplicationInstances -SAPSID $SAPSID
Write-Output ""
# List SAP Application layer VM
Write-Output ""
Write-WithTime "SAP Application layer VMs:"
Show-AzSAPSIDVMApplicationInstances -SAPVMs $SAPSIDApplicationVMs
# Get DBMS VMs
$SAPSIDDBMSVMs = Get-AzSAPDBMSInstances -SAPSID $SAPSID
# List SAP DBMS layer VM(s)
Write-Output ""
Write-WithTime "SAP DBMS layer VM(s):"
Show-AzSAPSIDVMDBMSInstances -SAPVMs $SAPSIDDBMSVMs
###################
# Stop SAP
###################
# Get SAP System Status
Write-Output ""
Get-AzSAPSystemStatus -SAPSIDApplicationVMs $SAPSIDApplicationVMs -PrintExecutionCommand $PrintExecutionCommand
# Stop SAP system
Write-Output ""
Stop-AzSAPSystem -SAPSIDApplicationVMs $SAPSIDApplicationVMs -SoftShutdownTimeInSeconds $SoftShutdownTimeInSeconds -PrintExecutionCommand $PrintExecutionCommand
# Get SAP System Status
Write-Output ""
Get-AzSAPSystemStatus -SAPSIDApplicationVMs $SAPSIDApplicationVMs -PrintExecutionCommand $PrintExecutionCommand
###################
# Stop DBMS
###################
# get DBMS Status
Write-Output ""
Get-AzDBMSStatus -SAPSIDDBMSVMs $SAPSIDDBMSVMs -PrintExecutionCommand $PrintExecutionCommand
# Stop DBMS
Write-Output ""
Stop-AzDBMS -SAPSIDDBMSVMs $SAPSIDDBMSVMs -PrintExecutionCommand $PrintExecutionCommand
# get DBMS Status
Write-Output ""
Get-AzDBMSStatus -SAPSIDDBMSVMs $SAPSIDDBMSVMs -PrintExecutionCommand $PrintExecutionCommand
###################
# Stop VMs
###################
Write-WithTime "Stopping VMs ...."
# Stop ABAP Application Servers (Dialog Instances) VMs
Write-Output ""
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDApplicationVMs -SAPInstanceType "SAP_D"
# Stop Java Application Servers VMs
Write-Output ""
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDApplicationVMs -SAPInstanceType "SAP_J"
# Stop ABAP ASCS Instance VMs
Write-Output ""
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDApplicationVMs -SAPInstanceType "SAP_ASCS"
# Stop ABAP DVEBMGS Instance VM
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDApplicationVMs -SAPInstanceType "SAP_DVEBMGS"
# Stop Java SCS Instance VMs
Write-Output ""
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDApplicationVMs -SAPInstanceType "SAP_SCS"
# Stop DBMS VMs
Write-Output ""
Stop-AzVMTagAndCheckVMStatus -SAPVMs $SAPSIDDBMSVMs -SAPInstanceType "SAP_DBMS"
####################################
# Convert the disks to Standard_LRS
####################################
if($ConvertDisksToStandard){
Convert-AzALLSAPSystemVMsCollectionManagedDisksToStandard -SAPSIDApplicationVMs $SAPSIDApplicationVMs -SAPSIDDBMSVMs $SAPSIDDBMSVMs
}
# Get end time
$EndTime = Get-Date
$ElapsedTime = $EndTime - $StartTime
Write-Output ""
Write-Output "Job succesfully finished."
Write-Output ""
Write-Output "SUMMARY:"
If($ConvertDisksToStandard){
Write-Output " - All disks set to 'Standard_LRS' type."
}else{
Write-Output " - All disks types are NOT changed."
}
Write-Output " - Virtual machine(s) stopped."
Write-Output " - DBMS stopped."
Write-Output " - SAP system '$SAPSID' stopped."
Write-Output ""
Write-Output "[INFO] Total time : $($ElapsedTime.Days) days, $($ElapsedTime.Hours) hours, $($ElapsedTime.Minutes) minutes, $($ElapsedTime.Seconds) seconds, $($ElapsedTime.Seconds) milliseconds."
###################
# POST-PROCESSING
###################
If($PostProcessingHook){
$body = @{
sid = $SAPSID
totalRuntime = "$($ElapsedTime.Hours)h$($ElapsedTime.Minutes)m$($ElapsedTime.Seconds)s"
status = "successfully"
user = $User
msg = "stopped"
}
Invoke-RestMethod -Method 'Post' -Uri $PostProcessingHook -Body ($body|ConvertTo-Json) -ContentType "application/json"
}
Else{
Write-Output "No webhook defined."
}
}
catch {
If($PostProcessingHook){
$body = @{
sid = $SAPSID
totalRuntime = "$($ElapsedTime.Hours)h$($ElapsedTime.Minutes)m$($ElapsedTime.Seconds)s"
status = "Stop SAP failed"
user = $User
msg = $_.ErrorDetails
}
Invoke-RestMethod -Method 'Post' -Uri $PostProcessingHook -Body ($body|ConvertTo-Json) -ContentType "application/json"
}Else{
Write-Output "No webhook defined."
}
}