-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path04_install_alwayson_fci2.ps1
More file actions
98 lines (79 loc) · 3.58 KB
/
Copy path04_install_alwayson_fci2.ps1
File metadata and controls
98 lines (79 loc) · 3.58 KB
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
[CmdletBinding()]
param (
[string]$ClusterName = 'CLUSTER01',
[string[]]$ClusterNodes = @('SQL01', 'SQL02'),
[string]$SqlNetworkName = 'FCI02',
[string]$SqlInstance = 'SQL2022',
[string]$SqlIP = '192.168.3.72',
[string]$SqlIPSubnet = '255.255.255.0',
[string]$SqlVersion = 2022
)
$ErrorActionPreference = 'Stop'
Import-Module -Name PSFramework
Import-Module -Name ActiveDirectory
Import-Module -Name dbatools
try {
$installCredential = [PSCredential]::new("ORDIX\Admin", (ConvertTo-SecureString -String 'P@ssw0rd' -AsPlainText -Force))
$sqlServiceCredential = [PSCredential]::new("ORDIX\gMSA-SQLServer$", [SecureString]::new())
Write-PSFMessage -Level Verbose -Message "Getting owner node for available disks"
$ownerNode = (Get-ClusterGroup -Cluster $ClusterName -Name 'Available Storage').OwnerNode.Name
if ($ownerNode -ne $ClusterNodes[0]) {
Write-PSFMessage -Level Verbose -Message "Moving available disks to first node"
$null = Move-ClusterGroup -Cluster $ClusterName -Name 'Available Storage' -Node $ClusterNodes[0]
}
Write-PSFMessage -Level Verbose -Message "Getting drive letter for $SqlInstance"
$cimSession = New-CimSession -ComputerName $ClusterNodes[0]
$driveLetter = (Get-Volume -CimSession $cimSession -FileSystemLabel $SqlInstance).DriveLetter
Write-PSFMessage -Level Verbose -Message "Using drive letter $driveLetter"
$cimSession | Remove-CimSession
$paramsInstallFailoverCluster = @{
ComputerName = $ClusterNodes[0]
InstanceName = $SqlInstance
Version = $SqlVersion
Configuration = @{
ACTION = 'InstallFailoverCluster'
FAILOVERCLUSTERNETWORKNAME = $SqlNetworkName
FAILOVERCLUSTERDISKS = "Cluster Disk $SqlInstance"
FAILOVERCLUSTERGROUP = "SQL Server ($SqlInstance)"
FAILOVERCLUSTERIPADDRESSES = "IPv4;$SqlIP;Cluster Network Public;$SqlIPSubnet"
INSTALLSQLDATADIR = "$($driveLetter):\$SqlInstance"
}
Feature = 'Engine'
AuthenticationMode = 'Mixed'
AdminAccount = $installCredential.UserName
EngineCredential = $sqlServiceCredential
AgentCredential = $sqlServiceCredential
Path = '\\fs\Software\SQLServer\ISO'
UpdateSourcePath = '\\fs\Software\SQLServer\CU'
Restart = $true
Credential = $installCredential
Confirm = $false
}
$paramsAddNode = @{
ComputerName = $ClusterNodes[1]
InstanceName = $SqlInstance
Version = $SqlVersion
Configuration = @{ ACTION = 'AddNode' }
EngineCredential = $sqlServiceCredential
AgentCredential = $sqlServiceCredential
Path = '\\fs\Software\SQLServer\ISO'
UpdateSourcePath = '\\fs\Software\SQLServer\CU'
Restart = $true
Credential = $installCredential
Confirm = $false
}
Write-PSFMessage -Level Host -Message "Installing first node"
$result = Install-DbaInstance @paramsInstallFailoverCluster
$result | Format-Table
if (-not $result.Successful) {
throw "Failed to install SQL Server on $($paramsInstallFailoverCluster.ComputerName)"
}
$server = Connect-DbaInstance -SqlInstance "$SqlNetworkName\$SqlInstance" -TrustServerCertificate
Write-PSFMessage -Level Host -Message "Installing second node"
$result = Install-DbaInstance @paramsAddNode
$result | Format-Table
if (-not $result.Successful) {
throw "Failed to install SQL Server on $($paramsAddNode.ComputerName)"
}
Write-PSFMessage -Level Host -Message 'Finished'
} catch { Write-PSFMessage -Level Warning -Message 'Failed' -ErrorRecord $_ }