-
Notifications
You must be signed in to change notification settings - Fork 17
/
Copy pathACS-ECS-BulkyActivateSQLServerEnterpriseEdition.json
176 lines (176 loc) · 10.7 KB
/
ACS-ECS-BulkyActivateSQLServerEnterpriseEdition.json
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
{
"FormatVersion": "OOS-2019-06-01",
"Description": {
"en": "SQL Server Enterprise Edition template activation",
"zh-cn": "SQL企业版服务模板激活",
"name-en": "ACS-ECS-BulkyActivateSQLServerEnterpriseEdition",
"name-zh-cn": "SQL服务模板激活",
"categories": [
"run_command",
"application_manage"
]
},
"Parameters": {
"regionId": {
"Type": "String",
"Label": {
"en": "RegionId",
"zh-cn": "地域ID"
},
"AssociationProperty": "RegionId",
"Default": "{{ ACS::RegionId }}"
},
"targets": {
"Type": "Json",
"Label": {
"en": "TargetInstance",
"zh-cn": "目标实例"
},
"AssociationProperty": "Targets",
"AssociationPropertyMetadata": {
"ResourceType": "ALIYUN::ECS::Instance",
"RegionId": "regionId"
}
},
"rateControl": {
"Label": {
"en": "RateControl",
"zh-cn": "任务执行的并发比率"
},
"Type": "Json",
"AssociationProperty": "RateControl",
"Default": {
"Mode": "Concurrency",
"MaxErrors": 0,
"Concurrency": 10
}
},
"OOSAssumeRole": {
"Label": {
"en": "OOSAssumeRole",
"zh-cn": "OOS扮演的RAM角色"
},
"Type": "String",
"Default": ""
}
},
"RamRole": "{{ OOSAssumeRole }}",
"Tasks": [
{
"Name": "getInstance",
"Description": {
"en": "Views the ECS instances",
"zh-cn": "获取ECS实例"
},
"Action": "ACS::SelectTargets",
"Properties": {
"ResourceType": "ALIYUN::ECS::Instance",
"RegionId": "{{ regionId }}",
"Filters": [
"{{ targets }}"
]
},
"Outputs": {
"instanceIds": {
"Type": "List",
"ValueSelector": "Instances.Instance[].InstanceId"
}
}
},
{
"Name": "tagInstance",
"Action": "ACS::ExecuteApi",
"Description": {
"en": "Creates and attaches tag to ECS instance",
"zh-cn": "创建并挂载标签到ECS实例"
},
"Properties": {
"Service": "ECS",
"API": "TagResources",
"Parameters": {
"RegionId": "{{ regionId }}",
"ResourceIds": [
"{{ ACS::TaskLoopItem }}"
],
"ResourceType": "Instance",
"Tags": [
{
"Key": "activation-execution-id",
"Value": "{{ ACS::ExecutionId }}"
}
]
}
},
"Loop": {
"RateControl": "{{ rateControl }}",
"Items": "{{ getInstance.instanceIds }}"
}
},
{
"Name": "runCommand",
"Action": "ACS::ECS::ActivateSoftware",
"Description": {
"en": "Execute cloud assistant command",
"zh-cn": "执行云助手命令"
},
"Properties": {
"regionId": "{{ regionId }}",
"commandContent": "<#\n\n.Synopsis\n change_sql_license.ps1\n\tThis script change the SQL Server License.\n\tOnly supports SQL Server 2012 and later versions.\n\n.DESCRIPTION\n\tDate: \t24/01/02\n\tAuthor: \tfangming.wfm@alibaba-inc.com\n\n.PARAMETER path\n The path to the SQL Server setup executable.\n.PARAMETER InstanceName\n The name of the SQL Server instance to be updated.\n.PARAMETER Version\n The version of SQL Server for which the license is to be changed. Supported values are: '2012_ent', '2016_ent', '2017_ent', '2019_ent'.\n.PARAMETER Password\n The password used to decrypt the encrypted License key.\n.EXAMPLE\n C:\\change_sql_license.ps1 -path \"C:\\Program Files\\Microsoft SQL Server\\140\\Setup Bootstrap\\SQL2017\\Setup.exe\" -InstanceName \"MSSQLSERVER\" -Version \"2017_ent\" -Password \"***\"\n\t C:\\change_sql_license.ps1 -path \"C:\\Program Files\\Microsoft SQL Server\\110\\Setup Bootstrap\\SQLServer2012\\Setup.exe\" -InstanceName \"MSSQLSERVER\" -Version \"2012_ent\" -Password \"***\"\n\n#>\n\nparam(\n [Parameter(Mandatory=$true)]\n [string]$path,\n \n [Parameter(Mandatory=$true)]\n [string]$InstanceName,\n \n [Parameter(Mandatory=$true)]\n [ValidateSet(\"2012_ent\", \"2016_ent\",\"2017_ent\",\"2019_ent\")]\n [string]$Version,\n \n [Parameter(Mandatory=$true)]\n [string]$Password\n)\n\n# Log File\n$name = $MyInvocation.MyCommand.Name # ScriptName\n$global:LogFile = New-Item -ItemType file \"C:\\logs\\$name.log\" -Force\n\n# Output to the screen and to the logfile\nFunction Write-Log($txt) {\n Add-Content $global:LogFile $txt\n Write-Host $txt -ForegroundColor Green\n}\n\n# Log header\n$date2 = Get-Date -Format 'yyyyMMddhhmmss'\n$username = whoami\n$hostname = hostname\n$os = Get-WmiObject -Class Win32_OperatingSystem | Select-Object -ExpandProperty Caption\nWrite-Log \"**********************\nStart time: $date2\nUsername : $username\nMachine : $hostname ($os)\n**********************\"\n\nFunction Change-SqlServerLicense {\n Param(\n [string]$setupExePath,\n [string]$InstanceName,\n [string]$DecryptedLicenseKey\n )\n \n $setupArguments = \"/q /ACTION=EditionUpgrade /INSTANCENAME=$InstanceName /PID=`\"$DecryptedLicenseKey`\" /IACCEPTSQLSERVERLICENSETERMS\"\n \n Try {\n Write-Log \"Starting SQL Server Edition Upgrade for instance $InstanceName with new License Key.\"\n \n # Run the setup command to upgrade the edition and replace the license key\n Start-Process -FilePath $setupExePath -ArgumentList $setupArguments -Wait -NoNewWindow\n \n Write-Log \"SQL Server license has been replaced successfully for instance $InstanceName.\"\n } Catch {\n\t\tWrite-Log \"An error occurred while trying to replace the SQL Server license for instance ${InstanceName}: $_\"\n }\n}\n\n# Function to decrypt an encrypted License key using a provided password\nFunction Decrypt-LicenseKey {\n Param(\n [string]$EncryptedLicenseKey,\n [string]$DecryptionPassword\n )\n \n # Convert the password to a 128-bit AES key\n $aesKey = [Text.Encoding]::UTF8.GetBytes($DecryptionPassword.PadRight(16).Substring(0,16))\n \n # Decrypt the License key\n $secureLicenseKey = ConvertTo-SecureString -String $EncryptedLicenseKey -Key $aesKey\n $bstr = [Runtime.InteropServices.Marshal]::SecureStringToBSTR($secureLicenseKey)\n Try {\n $decryptedLicenseKey = [Runtime.InteropServices.Marshal]::PtrToStringBSTR($bstr)\n } Finally {\n [Runtime.InteropServices.Marshal]::ZeroFreeBSTR($bstr)\n }\n \n return $decryptedLicenseKey\n}\n\n# Encrypted License keys for different versions\n$encryptedLicenseKeys = @{\n \"2012_ent\" = \"76492d1116743f0423413b16050a5345MgB8AEYAVQBJAE8AVQBtAEcALwBRAFQAcQBFAFcAUABlAEoAbAArAEkALwBSAEEAPQA9AHwAZQAyAGMAOABlADIAMABlADgAZQA2AGMANwAzAGUAOQA0ADQANAA3ADkAZQA3AGUANABkADQAMABiAGQAMgA4AGQAOABhADkAZgAwAGQAZQA3ADIAMABlAGUANAA4ADQAZABiADQAMgAyADEAMgAzAGQAMwA1ADUAMQA2ADYAOQAyADUAMwAyAGQANABlAGMANAAyADUAZABiADYANwA5ADIAMgBhADQANQA4ADcAYgA3ADEAOQA2AGUAMQBhAGIAZQBkAGQAYQA2ADUAZQAzADUAOQA1ADUANgBlAGUAMAA2AGUAMwAxADAANgBmAGYAMQBmAGUANQA1ADQANABkAA==\"\n \"2016_ent\" = \"76492d1116743f0423413b16050a5345MgB8ADYAWQBrAHcATABxACsAZAB6AFQASAA2ADQAaQBHADAANQAyAEwAYgBWAEEAPQA9AHwAYgBlADYAMAA5AGQAYgBkAGIAZgA3AGMAZABjAGMANABmADQAMAAxAGIAOQA0ADAAYQAwADAAZgAwADcANwBkADUAYgBkADQAMAA0ADcAYQBlAGUAMgBkADkAOQAzADYAOABjADkAMgAwADEANwBiAGEAYQA3ADYAOQAzAGIAYgBjAGEAZQA3AGYAYQBkAGIAMgBlAGMAOAA4AGYAZAA1ADkAMABmAGUAMgAzAGUANQBiADIANgBiAGYAMABiADMAZgA4AGMAOAA1ADEAMgAyAGEAZQA1AGYAOQAyAGQAMABmAGYAMAA3AGQANwA2AGYAMQA2ADYAZgBlADcANgA2AA==\"\n \"2017_ent\" = \"76492d1116743f0423413b16050a5345MgB8AHAAZwBNAGQARQA3AGEAbAAwAFUAcAAwAGYAUwBvAGMALwA2ADAAbQBoAEEAPQA9AHwANgAyAGUAMgBjAGUANwBlAGIAOQA5ADUAYQBlADYAZABlADMAYQA5ADkAYQBhAGIANABkADAAYgA1ADMAZABjADUANwBkAGQAOAA5ADIAYQBlAGEAOQBjADIAZAAyAGEAMgAzADAANQAyADcAYgBhADIANwA5AGUAOABkADgANwBmADQAYwA0ADEAMABlADAAYQA5ADcAMwA0AGEAZgBlADAAZgA3AGYANABlAGQAMgBiADQAZQBkAGYAYwA0ADMAZQBlAGUAOABjADAANAAwADQAMABmADAAMAA0ADEAOQBjADgAYwAwADAAOAAzADEAOQBhADkAMgA1ADQAMgBmAA==\"\n \"2019_ent\" = \"76492d1116743f0423413b16050a5345MgB8AEUAagB1AEMAUgB0ADkASQBNAFcARAB5ADcANwBWADkAYwBaAGsAUgBOAFEAPQA9AHwANgBkAGIAMgAyADgAMAA0ADAAMwBhAGMAOQBlAGUAMwA0ADMAZAAxADcAMwBlAGUAOAAzAGEAZQBjAGEAOAA4ADEAZQA0ADUANgBkADIAMwAyAGEAYgA3AGMANQAzADMANwBkAGYAYQBiADIAZQBkAGUAYwAwADgAMgBkADcAZgBiADcANgA0AGEANwA3AGEAZABkAGYAOAA3ADAAYQBjADQANgA1AGIAMAA0ADUAYQBmAGEANQA4ADAANwA4ADEAZgAwAGQAMQA2ADQAZQBmADAANQBmAGUAYQAzAGUAMgBkADEAMQA0AGUAOQA0ADEAOQBmADQAZgBiADcANAA1AA==\"\t\n}\n\n# Decrypt the License key\n$decryptedLicenseKey = Decrypt-LicenseKey -EncryptedLicenseKey $encryptedLicenseKeys[$Version] -DecryptionPassword $Password\n\n# Change the SQL Server license\nChange-SqlServerLicense -setupExePath $path -InstanceName $InstanceName -DecryptedLicenseKey $decryptedLicenseKey\n\n# Restart SQL Server service if the License was changed successfully\n$serviceName = if ($InstanceName -eq \"MSSQLSERVER\") { $InstanceName } else { \"MSSQL`$$InstanceName\" }\n\nTry {\n Write-Log \"Attempting to stop SQL Server service ${serviceName}.\"\n Stop-Service -Name $serviceName -Force -ErrorAction Stop\n Start-Sleep -Seconds 5 # Wait for 5 seconds to ensure the service stops\n\n Write-Log \"Attempting to start SQL Server service ${serviceName}.\"\n Start-Service -Name $serviceName\n Write-Log \"SQL Server service ${serviceName} restarted successfully.\"\n} Catch {\n Write-Log \"An error occurred while trying to restart the SQL Server service ${serviceName}: $_\"\n}",
"instanceId": "{{ ACS::TaskLoopItem }}",
"commandType": "RunPowerShellScript"
},
"Outputs": {
"commandOutput": {
"Type": "String",
"ValueSelector": "invocationOutput"
}
},
"Loop": {
"Items": "{{ getInstance.instanceIds }}",
"RateControl": "{{ rateControl }}",
"Outputs": {
"commandOutputs": {
"AggregateType": "Fn::ListJoin",
"AggregateField": "commandOutput"
}
}
}
}
],
"Outputs": {
"commandOutputs": {
"Type": "List",
"Value": "{{ runCommand.commandOutputs }}"
}
},
"Metadata": {
"ALIYUN::OOS::Interface": {
"ParameterGroups": [
{
"Parameters": [
"targets",
"regionId"
],
"Label": {
"default": {
"zh-cn": "配置参数",
"en": "Configure Parameters"
}
}
},
{
"Parameters": [
"rateControl",
"OOSAssumeRole"
],
"Label": {
"default": {
"zh-cn": "高级选项",
"en": "Control Options"
}
}
}
]
}
}
}