Microsoft SQL Server 容錯移轉叢集執行個體 (FCI) 是部署於多個 Windows Server 容錯移轉叢集 (WSFC) 節點的單一 SQL Server 執行個體。在任何時間點,叢集節點都會主動代管 SQL 執行個體。如果發生故障,WSFC 會自動將執行個體資源的擁有權轉移至另一個節點。
SQL Server FCI 需要將資料存放在共用儲存空間,以便在所有 WSFC 節點中存取。本指南說明如何部署 SQL Server 2022 容錯移轉叢集執行個體,並在多寫入端模式下使用 Hyperdisk Balanced High Availability 做為區域 (多區域) 共用儲存空間。
- 內部負載平衡器 (請參閱「執行 Windows Server 容錯移轉叢集」)
- 分散式網路名稱 (DNN) (請參閱「設定容錯移轉叢集執行個體的 DNN」)
本文假設您已在 Google Cloud 上部署 Active Directory,並對 SQL Server、Active Directory 和 Compute Engine 有基本瞭解。
目標
- 部署 WSFC,其中包含兩個 SQL Server VM 執行個體,以及做為檔案共用見證的第三個 VM 執行個體。
- 在 WSFC 上部署 SQL Server FCI。
- 設定負載平衡器或分散式網路名稱 (DNN),將流量導向 SQL Server 可用性群組。
- 模擬容錯移轉,確認叢集是否運作正常。
費用
本教學課程使用 Google Cloud的計費元件,包括:
- Compute Engine
- Cloud Load Balancing (使用 DNN 設定時不需執行此步驟)
使用 Pricing Calculator,根據您的預測使用量來產生預估費用。
事前準備
如要完成本指南,請先確認:
- Active Directory 網域,且至少有一個網域控制器。您可以使用 Managed Microsoft AD 建立 Active Directory 網域。或者,您也可以在 Compute Engine 上部署自訂 Active Directory 環境,並設定私人 DNS 轉送區域,將 DNS 查詢轉送至網域控制站。
- 有權將電腦加入網域,且可使用 RDP 登入的 Active Directory 使用者。如果您使用 Managed Microsoft AD,可以改用
setupadmin
使用者。 - Google Cloud 專案和虛擬私有雲,可連線至 Active Directory 網域控制站。
- 用於 WSFC VM 執行個體的子網路。
請務必查看多重寫入模式的 Hyperdisk 磁碟區限制,並選擇Hyperdisk Balanced High Availability 適用的區域
如要完成本指南,您也需要 Google Cloud 專案:
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Verify that billing is enabled for your Google Cloud project.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Verify that billing is enabled for your Google Cloud project.
完成本教學課程後,您可以刪除已建立的資源,避免繼續計費。
準備專案和網路
如要準備 Google Cloud 專案和虛擬私有雲,以部署 SQL Server FCI,請執行下列操作:
在 Google Cloud 控制台中,按一下「啟用 Cloud Shell」
按鈕,開啟 Cloud Shell。
初始化下列變數:
VPC_NAME=
VPC_NAME
SUBNET_NAME=SUBNET_NAME
其中:
VPC_NAME
:虛擬私有雲名稱SUBNET_NAME
:子網路名稱
設定預設的專案 ID:
gcloud config set project
PROJECT_ID
將
PROJECT_ID
替換為專案 ID。 Google Cloud設定預設區域:
gcloud config set compute/region
REGION
將
REGION
替換為要部署的區域 ID。
建立防火牆規則
如要允許用戶端連線至 SQL Server、允許 WSFC 節點之間的通訊,以及讓負載平衡器執行健康狀態檢查,您需要建立多項防火牆規則。如要簡化這些防火牆規則的建立程序,請使用網路標記:
- 這 2 個 WSFC 節點會加上
wsfc-node
標記。 - 所有伺服器 (包括見證伺服器) 都以
wsfc
標記加上註解。
建立使用這些網路標記的防火牆規則:
- 返回現有的 Cloud Shell 工作階段。
為 WSFC 節點建立防火牆規則:
SUBNET_CIDR=$(gcloud compute networks subnets describe $SUBNET_NAME --format=value\('ipCidrRange'\)) gcloud compute firewall-rules create allow-all-between-wsfc-nodes \ --direction=INGRESS \ --action=allow \ --rules=tcp,udp,icmp \ --enable-logging \ --source-tags=wsfc \ --target-tags=wsfc \ --network=$VPC_NAME \ --priority 10000 gcloud compute firewall-rules create allow-sql-to-wsfc-nodes \ --direction=INGRESS \ --action=allow \ --rules=tcp:1433 \ --enable-logging \ --source-ranges=$SUBNET_CIDR \ --target-tags=wsfc-node \ --network=$VPC_NAME \ --priority 10000
建立防火牆規則,允許探測器 Google Cloud 的 IP 範圍進行健康狀態檢查:(使用 DNN 設定時不必執行這項操作)
gcloud compute firewall-rules create allow-health-check-to-wsfc-nodes \ --direction=INGRESS \ --action=allow \ --rules=tcp \ --source-ranges=130.211.0.0/22,35.191.0.0/16 \ --target-tags=wsfc-node \ --network=$VPC_NAME \ --priority 10000
建立 VM 執行個體
現在要為容錯移轉叢集部署兩個 VM 執行個體。在任何時間點,只有其中一個 VM 會做為作用中的 FCI 節點,另一個節點則做為容錯移轉節點。這兩個 VM 執行個體必須具備下列條件:
- 已安裝 Windows Server 容錯移轉叢集和 SQL Server。
- 已啟用 Compute Engine WSFC 支援。
使用預先安裝 SQL Server 2022 的 SQL Server 進階映像檔。
如要針對容錯移轉情境提供關鍵票並達成仲裁,請部署第三個 VM 做為網域控制站和檔案共用見證。
返回現有的 Cloud Shell 工作階段。
為 WSFC 節點建立 specialize 指令碼。這個指令碼會安裝必要的 Windows 功能,並為 WSFC 和 SQL Server 建立防火牆規則:
cat << "EOF" > specialize-node.ps1 $ErrorActionPreference = "stop" # Install required Windows features Install-WindowsFeature Failover-Clustering -IncludeManagementTools Install-WindowsFeature RSAT-AD-PowerShell # Open firewall for WSFC netsh advfirewall firewall add rule name="Allow SQL Server health check" dir=in action=allow protocol=TCP localport=59997 # Open firewall for SQL Server netsh advfirewall firewall add rule name="Allow SQL Server" dir=in action=allow protocol=TCP localport=1433 EOF
建立 VM 執行個體,並將中繼資料金鑰
enable-wsfc
設為true
,在 WSFC 節點上啟用 Windows Server 容錯移轉叢集代理程式:MACHINE_TYPE=c3-standard-8 REGION=$(gcloud config get-value compute/region) ZONE_1=$REGION-a ZONE_2=$REGION-b gcloud compute instances create node-1 \ --zone $ZONE_1 \ --machine-type $MACHINE_TYPE \ --subnet $SUBNET_NAME \ --image-family sql-ent-2022-win-2022 \ --image-project windows-sql-cloud \ --tags wsfc,wsfc-node \ --boot-disk-size 50 \ --boot-disk-type hyperdisk-balanced \ --boot-disk-device-name node-1 \ --metadata enable-wsfc=true \ --metadata-from-file=sysprep-specialize-script-ps1=specialize-node.ps1 gcloud compute instances create node-2 \ --zone $ZONE_2 \ --machine-type $MACHINE_TYPE \ --subnet $SUBNET_NAME \ --image-family sql-ent-2022-win-2022 \ --image-project windows-sql-cloud \ --tags wsfc,wsfc-node \ --boot-disk-size 50 \ --boot-disk-type hyperdisk-balanced \ --boot-disk-device-name node-2 \ --metadata enable-wsfc=true \ --metadata-from-file=sysprep-specialize-script-ps1=specialize-node.ps1 gcloud compute instances create witness \ --machine-type n4-standard-2 \ --subnet $SUBNET_NAME \ --image-family=windows-2022 \ --image-project=windows-cloud \ --tags wsfc \ --boot-disk-size 50 \ --boot-disk-type hyperdisk-balanced \ --zone $ZONE_1 \ --metadata sysprep-specialize-script-ps1="add-windowsfeature FS-FileServer"
如要將這 3 個 VM 執行個體加入 Active Directory,請針對每個 VM 執行個體執行下列操作:
查看 VM 的序列埠輸出內容,監控初始化程序:
gcloud compute instances tail-serial-port-output
NAME
將
NAME
替換為 VM 執行個體名稱。等待約 3 分鐘,直到看到輸出內容
Instance setup finished
,然後按下 Ctrl+C。此時,VM 執行個體已可供使用。使用遠端桌面連線至 VM,並使用上一步建立的使用者名稱和密碼登入。
以滑鼠右鍵按一下「開始」按鈕 (或按 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
按一下「是」,確認提升權限提示。
將電腦加入 Active Directory 網域,然後重新啟動:
Add-Computer -Domain
DOMAIN -Restart
將
DOMAIN
換成 Active Directory 網域的 DNS 名稱。等待約 1 分鐘,讓裝置完成重新啟動。
以多重寫入模式建立 Hyperdisk Balanced High Availability 磁碟
現在,您可以在多重寫入模式下建立 Hyperdisk Balanced High Availability 磁碟,並將其附加至兩個 WSFC 節點。Hyperdisk 的優點之一,就是可設定 IOPS 和處理量,以符合應用程式需求。詳情請參閱「關於 Hyperdisk Balanced High Availability」。
- 返回現有的 Cloud Shell 工作階段。
建立 Hyperdisk Balanced High Availability 磁碟:
SIZE=200 gcloud compute disks create multiwriter-datadisk-1 \ --size $SIZE \ --provisioned-throughput 200 \ --provisioned-iops 5000 \ --access-mode READ_WRITE_MANY \ --type hyperdisk-balanced-high-availability \ --replica-zones $ZONE_1,$ZONE_2
將磁碟連接至
node-1
:gcloud compute instances attach-disk node-1 \ --disk multiwriter-datadisk-1 \ --zone $ZONE_1 \ --disk-scope=regional
將磁碟連接至
node-2
:gcloud compute instances attach-disk node-2 \ --disk multiwriter-datadisk-1 \ --zone $ZONE_2 \ --disk-scope=regional
預留叢集 IP 位址
您現在已在虛擬私有雲中保留兩個靜態 IP 位址。一個 IP 位址做為 WSFC 叢集 IP 位址,另一個則供內部負載平衡器使用。
為內部負載平衡器保留靜態 IP,並在名為
LOADBALANCER_ADDRESS
的新環境變數中擷取位址:gcloud compute addresses create wsfc \ --region $REGION \ --subnet $SUBNET_NAME LOADBALANCER_ADDRESS=$(gcloud compute addresses describe wsfc \ --region $REGION \ --format=value\(address\)) && \ echo "Load Balancer IP: $LOADBALANCER_ADDRESS"
請記下 IP 位址,稍後會用到。
預留另一個靜態 IP 位址做為叢集 IP:(使用 DNN 設定時不必這麼做)
gcloud compute addresses create wsfc-cluster \ --subnet $SUBNET_NAME \ --region $REGION && \ CLUSTER_ADDRESS=$(gcloud compute addresses describe wsfc-cluster \ --region $REGION \ --format=value\(address\)) && \ echo "Cluster IP: $CLUSTER_ADDRESS"
請記下 IP 位址,稍後會用到。
專案和 VPC 現在已準備好部署 WSFC 和 SQL Server。
建立見證檔案共用
如要準備 witness
做為檔案共用見證,請建立檔案共用,並授予自己和兩個 WSFC 節點檔案共用存取權:
witness
使用遠端桌面連線。 使用網域使用者帳戶登入。- 以滑鼠右鍵按一下「開始」按鈕 (或按 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
- 按一下「是」,確認提升權限提示。
建立見證資料夾並共用:
New-Item 'C:\QWitness' -type directory New-SmbShare ` -Name QWitness ` -Path 'C:\QWitness' ` -Description 'SQL File Share Witness' ` -FullAccess $env:username,node-1$,node-2$ Grant-SmbShareAccess -Name 'QWitness' -AccountName 'node-1$' -AccessRight Full -Force Grant-SmbShareAccess -Name 'QWitness' -AccountName 'node-2$' -AccessRight Full -Force
部署容錯移轉叢集
現在您可以使用 VM 執行個體部署 WSFC 和 SQL Server。
部署 WSFC
現在可以開始建立容錯移轉叢集:
node-1
使用遠端桌面連線。 使用網域使用者帳戶登入。- 以滑鼠右鍵按一下「開始」按鈕 (或按 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
- 按一下「是」,確認提升權限提示。
建立新叢集:
- 負載平衡器設定
New-Cluster ` -Name sql-cluster ` -Node node-1,node-2 ` -NoStorage ` -StaticAddress
CLUSTER_ADDRESS
將
CLUSTER_ADDRESS
替換為您先前建立的叢集 IP 位址。- DNN 設定
New-Cluster ` -Name sql-cluster ` -Node node-1,node-2 ` -NoStorage ` -ManagementPointNetworkType Distributed
返回
witness
的 PowerShell 工作階段,授予叢集的虛擬電腦物件存取檔案共用區的權限:icacls C:\QWitness\ /grant 'sql-cluster$:(OI)(CI)(M)' Grant-SmbShareAccess ` -Name QWitness ` -AccountName 'sql-cluster$' ` -AccessRight Full ` -Force
返回
node-1
上的 PowerShell 工作階段,然後將叢集設為使用witness
上的檔案共用做為叢集仲裁:Set-ClusterQuorum -FileShareWitness \\witness\QWitness
確認叢集是否已成功建立:
Test-Cluster
您可能會看到一些可直接忽略的警告:
WARNING: System Configuration - Validate All Drivers Signed: The test reported some warnings.. WARNING: Network - Validate Network Communication: The test reported some warnings.. WARNING: Test Result: HadUnselectedTests, ClusterConditionallyApproved Testing has completed for the tests you selected. You should review the warnings in the Report. A cluster solution is supported by Microsoft only if you run all cluster validation tests, and all tests succeed (with or without warnings).
您也可以執行
cluadmin.msc
,藉此啟動容錯移轉叢集管理員 MMC 嵌入式管理單元,並查看叢集的健康狀態。如果您使用受管理 AD,請將 WSFC 用的電腦帳戶新增至「Cloud Service Domain Join Accounts」群組,以便將電腦加入網域:
Add-ADGroupMember ` -Identity "Cloud Service Domain Join Accounts" ` -Members sql-cluster$
新增叢集磁碟
現在請初始化先前建立的共用 Hyperdisk Balanced High Availability 磁碟,並將其新增至叢集:
- 返回
node-1
的 PowerShell 工作階段。 初始化 Hyperdisk Balanced High Availability 磁碟:
$NodeName = [System.Net.Dns]::GetHostName() $ClusterDisks = Get-PhysicalDisk -CanPool $True | Where-Object { ($_ | Get-PhysicalDiskStorageNodeView | Select-Object -Property StorageNodeObjectId) -like ('*' + $NodeName + '*') } Initialize-Disk -Number $ClusterDisks[0].DeviceId
在磁碟上建立使用 NTFS 檔案系統的新分區,並以 64 KB 區塊大小格式化磁碟:
New-Partition -DiskNumber $ClusterDisks[0].DeviceId ` -UseMaximumSize -DriveLetter D | Format-Volume ` -FileSystem NTFS -newfilesystemlabel DataDisk -AllocationUnitSize 65536
將磁碟新增至叢集:
Get-ClusterAvailableDisk | Add-ClusterDisk
由於底層的 Hyperdisk Balanced High Availability 磁碟已附加至兩個 VM 執行個體,因此磁碟會自動顯示在
node-2
上。開啟 容錯移轉叢集管理員 MMC 嵌入式管理單元:
cluadmin.msc
測試磁碟容錯移轉
您現在可以選擇測試磁碟容錯移轉是否正常運作:
node-2
使用遠端桌面連線。 使用網域使用者帳戶登入。- 在「開始」按鈕上按一下滑鼠右鍵 (或按下 Win+X 鍵),然後選取「執行」。
- 輸入
cluadmin.msc
,然後選取「確定」。 在左側視窗窗格中,依序前往「容錯移轉叢集管理員」>「sql-cluster」>「存放裝置」>「磁碟」。
您應該會看到名為「Cluster Disk 1」的磁碟,且「Owner node」設為
node-1
。返回 Cloud Shell 並重設
node-1
VM,模擬容錯移轉:gcloud compute instances reset node-1
返回
node-2
上的「容錯移轉叢集管理員」。重複按下 F5 鍵重新整理檢視畫面,觀察磁碟狀態。
大約 30 秒後,擁有者節點應會自動切換為
node-2
。
移除預設的 SQL Server 安裝項目
現在請從這兩個節點移除預設的 SQL Server 安裝作業,並以新的 FCI 設定取代。
針對兩個 WSFC 節點 node-1
和 node-2
,執行下列步驟:
- 以滑鼠右鍵按一下「開始」按鈕 (或按下 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
- 按一下「是」,確認提升權限提示。
移除預設的 SQL Server 執行個體:
C:\sql_server_install\Setup.exe /Action=Uninstall /FEATURES=SQL,AS,IS,RS /INSTANCENAME=MSSQLSERVER /Q
移除 Microsoft OLE 驅動程式:
Get-Package -Name "Microsoft OLE*" | Uninstall-Package -Force
移除 Microsoft ODBC 驅動程式:
Get-Package -Name "Microsoft ODBC*" | Uninstall-Package -Force
重新啟動電腦:
Restart-Computer
等待約 1 分鐘,讓裝置完成重新啟動。
安裝 SQL Server FCI
安裝新的 FCI 設定前,請先確認 node-1
是叢集中的有效節點:
node-1
使用遠端桌面重新連線,並使用網域使用者登入。- 在「開始」按鈕上按一下滑鼠右鍵 (或按下 Win+X 鍵),然後選取「執行」。
- 輸入
cluadmin.msc
,然後選取「確定」。 在左側視窗窗格中,依序前往「Failover Cluster Manager」>「sql-cluster」。
確認目前的主機伺服器已設為
node-1
。如果目前的主機伺服器設為
node-2
,請在左側視窗窗格中按一下滑鼠右鍵,選取「sql-cluster」,然後依序點選「More actions」>「Move core cluster resources」>「Select node…」>「node-1」,並按一下「OK」。在左側視窗窗格中,依序前往「容錯移轉叢集管理員」>「sql-cluster」>「存放裝置」>「磁碟」。
確認「Cluster Disk 1」擁有者節點已設為
node-1
。如果擁有者節點設為
node-2
,請依序點選「移動可用儲存空間」>「選取節點...」> node-1 從右側的「動作」選單中按一下「確定」。
現在請在 node-1
上建立新的 SQL Server 容錯移轉叢集安裝:
- 以滑鼠右鍵按一下「開始」按鈕 (或按下 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
- 按一下「是」,確認提升權限提示。
為 SQL Server 和 SQL 代理程式建立網域使用者帳戶,並指派密碼:
$Credential = Get-Credential -UserName sql_server -Message 'Enter password' New-ADUser ` -Name "sql_server" ` -Description "SQL Agent and SQL Admin account." ` -AccountPassword $Credential.Password ` -Enabled $true -PasswordNeverExpires $true
啟動 SQL Server 設定:
& c:\sql_server_install\setup.exe
在左側選單中,選取「安裝」。
選取「New SQL Server failover cluster installation」(安裝新的 SQL Server 容錯移轉叢集)
在「版本」頁面中,勾選「我只有 SQL Server 授權」,然後選取「下一步」。
在「授權條款」頁面中,詳閱條款,然後選取「下一步」。
在「Microsoft Update」頁面中,選取「Next」開始安裝。
在「Install Failover Cluster Rules」(安裝容錯移轉叢集規則) 頁面上,您會看到「MSCS cluster verification warnings」(MSCS 叢集驗證警告)和「Windows firewall」(Windows 防火牆)警告。您可以忽略這些警告,然後選取「下一步」。
在「Feature Selection」(功能選取) 頁面中,選取「Database Engine Services」(資料庫引擎服務),然後選取「Next」(下一步)。
在「Instance Configuration」頁面中,輸入
sql
做為網路名稱,然後選取「Next」。在「叢集資源群組」頁面中,保留預設值並選取「下一步」。
在「Cluster Disk Selection」(叢集磁碟選取) 頁面中,選取「Cluster Disk 1」(叢集磁碟 1),然後選取「Next」(下一步)。
在「叢集網路設定」頁面中,設定下列設定,然後選取「下一步」:
- DHCP:清除
- IP 位址:輸入內部負載平衡器的 IP 位址。
在「伺服器設定」頁面中,為「SQL Server Agent」和「SQL Server Database Engine」設定下列設定:
- 帳戶名稱:
DOMAIN\sql_server
,其中DOMAIN
是 Active Directory 網域的 NetBIOS 名稱 - 密碼:輸入您先前建立的密碼
- 帳戶名稱:
選取「排序規則」分頁,然後選取要使用的排序規則。 然後點選「下一步」。
在「Database Engine Configuration」(資料庫引擎設定) 頁面中,選取「Add current user」(新增目前使用者),將目前使用者指定為 SQL Server 管理員。然後選取「下一步」。
在「Ready to Install」(準備安裝) 頁面,檢查設定,然後選取「Install」(安裝)。
安裝完成後,選取「關閉」。
現在將 node-2
新增至 SQL Server 容錯移轉叢集:
node-2
使用遠端桌面連線,然後使用網域使用者登入。- 以滑鼠右鍵按一下「開始」按鈕 (或按 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
- 按一下「是」,確認提升權限提示。
啟動 SQL Server 設定:
& c:\sql_server_install\setup.exe
在左側選單中,選取「安裝」。
選取「Add node to a SQL Server failover cluster」(將節點新增至 SQL Server 容錯移轉叢集)。
按照安裝精靈的指示操作,並接受預設設定,直到看到「服務帳戶」頁面為止。
在「Service Accounts」(服務帳戶) 頁面中,輸入您先前為「SQL Server Agent」(SQL Server 代理程式) 和「SQL Server Database Engine」(SQL Server 資料庫引擎) 建立的密碼。然後選取「下一步」。
在「Ready to Install」(準備安裝) 頁面,檢查設定,然後選取「Install」(安裝)。
安裝完成後,選取「關閉」。
設定健康狀態檢查
最後一個步驟是設定叢集,公開可供內部負載平衡器使用的健康狀態檢查端點:
- 返回
node-2
的 PowerShell 工作階段 使用負載平衡器的 IP 位址初始化變數。
$LoadBalancerIP = '
IP_ADDRESS
'將
IP_ADDRESS
換成您先前保留的wsfc
位址 IP 位址。設定容錯移轉叢集,以回應健康狀態檢查服務:
$SqlGroup = Get-ClusterGroup | Where-Object {$_.Name.StartsWith("SQL Server")} $SqlIpAddress = Get-ClusterResource | Where-Object {$_.Name.StartsWith("SQL IP Address")} $SqlIpAddress | Set-ClusterParameter -Multiple @{ 'Address'=$LoadBalancerIP; 'ProbePort'= 59997; 'SubnetMask'='255.255.255.255'; 'Network'= (Get-ClusterNetwork).Name; 'EnableDhcp'=0; }
重新啟動叢集資源:
$SqlIpAddress | Stop-ClusterResource $SqlIpAddress | Start-ClusterResource
重新啟動叢集群組:
$SqlGroup | Stop-ClusterGroup $SqlGroup | Start-ClusterGroup
建立內部負載平衡器
為了為 SQL Server 用戶端提供單一端點,您現在要部署內部負載平衡器。負載平衡器會使用健康狀態檢查,確保流量導向 WSFC 的有效節點。
- 返回現有的 Cloud Shell 工作階段。
建立非代管執行個體群組,並將兩個節點新增至該群組:
gcloud compute instance-groups unmanaged create wsfc-group-1 \ --zone $ZONE_1 gcloud compute instance-groups unmanaged add-instances wsfc-group-1 \ --zone $ZONE_1 \ --instances node-1 gcloud compute instance-groups unmanaged create wsfc-group-2 \ --zone $ZONE_2 gcloud compute instance-groups unmanaged add-instances wsfc-group-2 \ --zone $ZONE_2 \ --instances node-2
建立健康狀態檢查,供負載平衡器用來判斷哪個是有效節點。
gcloud compute health-checks create tcp wsfc-healthcheck \ --check-interval="2s" \ --healthy-threshold=1 \ --unhealthy-threshold=2 \ --port=59997 \ --timeout="1s"
健康狀態檢查探測通訊埠
59997
,也就是您先前為 WSFC 叢集 IP 位址設定的ProbePort
通訊埠。建立後端服務並新增執行個體群組:
gcloud compute backend-services create wsfc-backend \ --load-balancing-scheme internal \ --region $REGION \ --health-checks wsfc-healthcheck \ --protocol tcp gcloud compute backend-services add-backend wsfc-backend \ --instance-group wsfc-group-1 \ --instance-group-zone $ZONE_1 \ --region $REGION gcloud compute backend-services add-backend wsfc-backend \ --instance-group wsfc-group-2 \ --instance-group-zone $ZONE_2 \ --region $REGION
建立內部負載平衡器:
gcloud compute forwarding-rules create wsfc-sql \ --load-balancing-scheme internal \ --address $LOADBALANCER_ADDRESS \ --ports 1433 \ --network $VPC_NAME \ --subnet $SUBNET_NAME \ --region $REGION \ --backend-service wsfc-backend
設定 DNN 資源和 DNN DNS 名稱
與內部負載平衡器類似,DNN 資源可做為 SQL Server 用戶端的單一閘道。容錯移轉期間,叢集會將流量順暢地轉送至有效的 SQL Server FCI 節點。用戶端會使用 DNS 名稱連線至 SQL Server FCI。
- 返回
node-1
的 PowerShell 工作階段。 執行指令碼來建立 DNN 資源
$DNNResourceName='fci-dnn' $DNN_DNSName='fcidnn' # create the DNN resource Add-ClusterResource -Name $DNNResourceName -ResourceType 'Distributed Network Name' -Group 'SQL Server (MSSQLSERVER)' # set the DNS name of the DNN resource Get-ClusterResource -Name $DNNResourceName | Set-ClusterParameter -Name DnsName -Value $DNN_DNSName # start the DNN resource Start-ClusterResource -Name $DNNResourceName
重新啟動「
node-1
」和「node-2
」
測試容錯移轉叢集
您已完成容錯移轉叢集的安裝作業,但仍須測試叢集是否正常運作。
準備用戶端
建立新的 VM 執行個體,用來連線至容錯移轉叢集:
- 返回現有的 Cloud Shell 工作階段。
建立新的 VM 執行個體:
gcloud compute instances create sqlclient \ --machine-type n2-standard-2 \ --subnet $SUBNET_NAME \ --image-family sql-ent-2022-win-2022 \ --image-project windows-sql-cloud \ --boot-disk-size 50 \ --boot-disk-type pd-ssd
查看 VM 的序列埠輸出內容,監控初始化程序:
gcloud compute instances tail-serial-port-output sqlclient
請等待約 3 分鐘,直到看到「Instance setup finished」輸出內容,然後按下 Ctrl+C。此時,VM 執行個體已可供使用。
使用遠端桌面連線至 VM,並使用上一步建立的使用者名稱和密碼登入。
以滑鼠右鍵按一下「開始」按鈕 (或按 Win+X 鍵),然後按一下「Windows PowerShell (系統管理員)」。
按一下「是」,確認提升權限提示。
將電腦加入 Active Directory 網域:
Add-Computer -Domain
DOMAIN
將
DOMAIN
換成 Active Directory 網域的 DNS 名稱。重新啟動電腦:
Restart-Computer
等待約 1 分鐘,讓裝置完成重新啟動。
執行測試
使用 sqlclient
VM 測試是否能連線至容錯移轉叢集,並驗證容錯移轉是否正常運作:
sqlclient
使用遠端桌面連線,然後使用網域使用者登入。- 在「開始」按鈕上按一下滑鼠右鍵 (或按下 Win+X 鍵),然後按一下「Windows PowerShell」。
使用網路名稱
sql
連線至 SQL Server 叢集,並查詢dm_os_cluster_nodes
資料表:& "$env:ProgramFiles\Microsoft SQL Server\Client SDK\ODBC\170\Tools\Binn\SQLCMD.EXE" ` -S
SQL_SERVER_NAME
-E -Q "SELECT * FROM sys.dm_os_cluster_nodes"將
SQL_SERVER_NAME
替換為負載平衡器設定的sql
,或 DNN 設定的fcidnn
。輸出內容應如下所示:
NodeName status status_description is_current_owner ------------------------------ ----------- ------------------ ---------------- NODE-1 0 up 1 NODE-2 0 up 0 (2 rows affected)
請注意,
node-1
是 SQL Server 容錯移轉叢集資源目前的擁有者。返回 Cloud Shell,並關閉 node-1 VM 來測試容錯移轉情境。
gcloud compute instances stop node-1
重複查詢:
& "$env:ProgramFiles\Microsoft SQL Server\Client SDK\ODBC\170\Tools\Binn\SQLCMD.EXE" ` -S
SQL_SERVER_NAME
-E -Q "SELECT * FROM sys.dm_os_cluster_nodes"將
SQL_SERVER_NAME
替換為負載平衡器設定的sql
,或 DNN 設定的fcidnn
。輸出畫面應如下所示:
NodeName status status_description is_current_owner ------------------------------ ----------- ------------------ ---------------- NODE-1 1 down 0 NODE-2 0 up 1 (2 rows affected)
請注意,雖然失去
node-1
,查詢還是執行成功,並顯示node-2
現在是容錯移轉叢集目前的擁有者。
清除所用資源
完成教學課程後,您可以清除所建立的資源,這樣資源就不會繼續使用配額,也不會產生費用。下列各節將說明如何刪除或關閉這些資源。
刪除專案
如要避免付費,最簡單的方法就是刪除您為了本教學課程所建立的專案。
如要刪除專案:
- In the Google Cloud console, go to the Manage resources page.
- In the project list, select the project that you want to delete, and then click Delete.
- In the dialog, type the project ID, and then click Shut down to delete the project.
後續步驟
- 進一步瞭解如何以多重寫入模式共用磁碟。
- 瞭解如何設定使用儲存空間直接存取的 SQL Server 容錯移轉叢集執行個體。