叢集對叢集儲存體複寫
儲存體複本可以在叢集之間複寫磁碟區,包括使用儲存空間直接存取來複寫叢集。 管理與設定類似於伺服器對伺服器複寫。
您將在叢集對叢集設定中,設定這些電腦與存放裝置,其中一個叢集會將自己那組存放裝置複寫為另一叢集與它那組存放裝置。 雖然並非必要,但這些節點及其存放裝置應位在不同的實體網站。
重要
這項測試中的四部伺服器即為範例。 您可以在每個叢集中使用 Microsoft 支援之任意數目的伺服器,目前儲存空間直接存取叢集支援 8 個,而共用存放裝置叢集支援 64 個。
本指南並未涵蓋設定儲存空間直接存取的內容。 如需設定儲存空間直接存取的詳細資訊,請參閱儲存空間直接存取概觀。
本逐步解說使用下列環境做為範例︰
兩個名為 SR-SRV01 和 SR-SRV02 的成員伺服器,在後來形成名為 SR-SRVCLUSA 的叢集。
兩個名為 SR-SRV03 和 SR-SRV04 的成員伺服器,在後來形成名為 SR-SRVCLUSB 的叢集。
代表示兩個不同資料中心的一對邏輯「網站」,一個名為 Redmond,而另一個名 Bellevue。
圖 1:叢集對叢集複寫
必要條件
- Active Directory 網域服務樹系 (不需要執行 Windows Server 2016)。
- 執行 Windows Server 2019 或 Windows Server 2016 Datacenter Edition 的 4-128 伺服器 (兩個 2-64 伺服器叢集)。 如果您執行的是 Windows Server 2019,且確定只複寫大小上限為 2 TB 的單一磁碟區,則可以改為使用 Standard Edition。
- 兩組儲存體,使用 SAS JBOD、光纖通道 SAN、共用 VHDX、儲存空間直接存取,或 iSCSI 目標。 儲存體應包含 HDD 和 SSD 兩者混合的媒體。 您必須設定每組存放裝置只能供各自的叢集使用,叢集之間不得共用存取。
- 每組存放裝置必須允許建立至少兩個虛擬磁碟,一個供複寫的資料使用,另一個供記錄檔使用。 實體存放裝置的所有資料磁碟上,必須都要有相同的磁區大小。 實體存放裝置的所有記錄檔磁碟上,必須都要有相同的磁區大小。
- 每部伺服器上至少要有一個乙太網路/TCP 連線,以進行同步複寫,但最好是 RDMA。
- 適當的防火牆與路由器規則,以允許在所有節點之間提供 ICMP、SMB (連接埠 445,若為 SMB 直接傳輸,需再加上 5445) 以及 WS-MAN (連接埠 5985) 雙向流量。
- 針對同步複寫,伺服器間的網路頻寬必須足以容納您的 IO 寫入工作負載,以及平均 =5ms 的來回延遲。 非同步複寫沒有建議的延遲值。
- 複寫的儲存體不可位於包含 Windows 作業系統資料夾的磁碟機上。
- 儲存空間直接複製有一些重要的注意事項 & 限制 - 請查看下面的詳細資訊。
這其中許多需求都可以使用 Test-SRTopology
Cmdlet 來判斷。 如果您至少在一部伺服器上安裝儲存體複本或儲存體複本管理工具功能,便可存取此工具。 只要安裝此 Cmdlet 即可,不需要將儲存體複本設定為使用此工具。 詳細資訊收錄於下列步驟。
步驟 1:佈建作業系統、功能、角色、儲存體及網路
使用 Windows Server (桌面體驗) 的安裝類型,在所有四個伺服器節點上安裝 Windows Server。
新增網路資訊並加入網域,然後予以重新啟動。
重要
從此時開始,一律要以所有伺服器上內建系統管理員群組成員的網域使用者身分登入。 請務必記住,在圖形化伺服器安裝或 Windows 10 電腦上執行時,一開始要提升 Windows PowerShell 和 CMD 命令提示字元的權限。
將第一組 JBOD 儲存體機箱、iSCSI 目標、FC SAN 或本機固定式磁碟 (DAS) 儲存體連線到 Redmond 網站中的伺服器。
將第二組儲存體連線到 Bellevue 網站中的伺服器。
視需要在四個節點上全部安裝最新的廠商存放裝置和機箱韌體與驅動程式、最新的廠商 HBA 驅動程式、最新的廠商 BIOS/UEFI 韌體、最新的廠商網路驅動程式,以及最新的主機板晶片組驅動程式。 視需要重新啟動節點。
注意
如需設定共用儲存體和網路硬體,請參閱硬體廠商的文件。
確定伺服器的 BIOS/UEFI 設定能提供高效能,例如停用 C-State、設定 QPI 速度、啟用 NUMA,以及設定最高的記憶體頻率。 務必將 Windows Server 中的電源管理設定為高效能。 視需要重新啟動。
如下所示設定角色:
圖形化方法
執行 ServerManager.exe,並新增所有伺服器節點以建立伺服器群組。
在每個節點上安裝 [檔案伺服器] 和 [儲存體複本] 角色和功能,然後予以重新啟動。
Windows PowerShell 方法
在 SR-SRV04 或遠端管理電腦上,於 Windows PowerShell 主控台執行下列命令,為延展式叢集在這四個節點上安裝所需的功能與角色,並將它們重新啟動:
$Servers = 'SR-SRV01','SR-SRV02','SR-SRV03','SR-SRV04' $Servers | ForEach { Install-WindowsFeature -ComputerName $_ -Name Storage-Replica,Failover-Clustering,FS-FileServer -IncludeManagementTools -restart }
如需這些步驟的詳細資訊,請參閱安裝或解除安裝角色、角色服務或功能
如下所示設定儲存體:
重要
- 您必須在每個機箱上建立兩個磁碟區︰一個供資料使用,而另一個供記錄檔使用。
- 記錄檔和資料磁碟必須初始化為 GPT,而非 MBR。
- 這兩個資料磁碟區的大小必須相同。
- 這兩個記錄檔磁碟區的大小應該相同。
- 所有複寫的資料磁碟都必須有相同的磁區大小。
- 所有記錄檔磁碟都必須有相同的磁區大小。
- 記錄檔磁碟區應該使用 Flash 架構的儲存體,例如 SSD。 Microsoft 建議記錄儲存體比資料儲存體更快。 記錄磁碟區絕對不能用於其他工作負載。
- 資料磁碟可以使用 HDD、SSD 或階層式組合,而且可以使用鏡像或同位空間,或是 RAID 1 或 10、RAID 5 或 RAID 50。
- 記錄磁碟區預設必須至少有 8 GB,而且根據記錄需求,可能會更大或更小。
- 在搭配 NVME 或 SSD 快取使用儲存空間直接存取 (儲存空間直接存取) 時,當您設定儲存空間直接存取叢集之間的儲存複本的複寫時,您會看到延遲大於預期的增加。 在效能 + 容量配置中使用 NVME 和 SSD,且沒有 HDD 層或容量層時,延遲的變更會比看到的要高得多,並按比例顯示。
相較於較慢的媒體,此問題是因為 SR 記錄機制內的架構限制,加上 NVME 的極低延遲。 使用儲存空間直接存取儲存空間直接存取快取時,SR 記錄的所有 IO 以及應用程式的最新讀取/寫入 IO 都會發生在快取中,且永遠不會發生在效能或容量層上。 這表示所有 SR 活動都會在相同的速度媒體上發生 - 不建議使用此設定 (請參閱 https://aka.ms/srfaq 以取得記錄建議)。
搭配 HDD 使用儲存空間直接存取時,您無法停用或避免快取。 因應措施是,如果只使用 SSD 和 NVME,您可以只設定效能和容量層級。 如果使用該組態,並將 SR 記錄只放在效能層,且其服務的資料磁碟區僅位於容量層上,您將能避免上述高延遲問題。 這可以透過混合更快和更慢的 SSD 和沒有 NVME 來完成。
此因應措施當然不理想,且有些客戶可能無法使用。 SR 小組正努力在未來進行最佳化和更新的記錄機制,以減少這些發生的人為瓶頸。 對此沒有適用的 ETA,但當 TAP 客戶可供測試時,此常見問題將會被更新。
- 對於 JBOD 機箱:
請確定每個叢集只能看到該網站的存放裝置機箱,同時已正確設定 SAS 連線。
遵循在獨立伺服器上部署儲存空間中提供的步驟 1-3,使用 Windows PowerShell 或伺服器管理員,使用儲存空間佈建儲存體。
- 對於 iSCSI 目標存放裝置:
請確定每個叢集只能看到該網站的存放裝置機箱。 如果使用 iSCSI,您應該使用一張以上的網路介面卡。
使用廠商的文件來佈建儲存體。 如果使用 Windows iSCSI 目標,請參閱 iSCSI 目標區塊儲存體,作法。
- 針對 FC SAN 儲存體:
請確定每個叢集只能看到該網站的儲存體機箱,同時您已將主機適當地分區。
使用廠商的文件來佈建儲存體。
- 對於儲存空間直接存取:
請確定每個叢集只能藉由部署儲存空間直接存取來查看該站台的存放裝置機箱。
請確定 SR 記錄磁碟區一律位於最快的快閃儲存體上,且資料磁碟區位於較慢的高容量儲存體上。
啟動 Windows PowerShell,然後使用
Test-SRTopology
Cmdlet 來判斷您是否符合所有儲存體複本需求。 您可以在僅查看需求的模式中,使用此 Cmdlet 進行快速測試,還可以在評估長時間執行效能的模式中使用。 例如,MD c:\temp Test-SRTopology -SourceComputerName SR-SRV01 -SourceVolumeName f: -SourceLogVolumeName g: -DestinationComputerName SR-SRV03 -DestinationVolumeName f: -DestinationLogVolumeName g: -DurationInMinutes 30 -ResultPath c:\temp
重要
在指定的來源磁碟區上,若在評估期間使用的測試伺服器沒有任何寫入 IO 負載,請考慮新增工作負載,否則不會產生有用的報告。 您應該使用和實際執行類似的工作負載來測試,才能看出實際的數字與建議的記錄檔大小。 或者,只要在測試期間,將一些檔案複製到來源磁碟區,或下載並執行 DISKSPD 以產生寫入 IO 即可。 例如,會寫入 D: 磁碟區長達五分鐘的少量 IO 工作負載範例︰
Diskspd.exe -c1g -d300 -W5 -C5 -b8k -t2 -o2 -r -w5 -h d:\test.dat
檢查 TestSrTopologyReport.html 報告,確定您符合儲存體複本需求。
步驟 2:設定兩個向外延展檔案伺服器容錯移轉叢集
您現在將建立兩個標準的容錯移轉叢集。 完成設定、驗證及測試之後,您將會使用儲存體複本加以複寫。 您可以直接在叢集節點,或從包含 Windows Server 遠端伺服器管理工具的遠端系統管理電腦執行下列步驟。
圖形化方法
針對每個網站中的節點執行 cluadmin.msc。
驗證建議的叢集並分析結果,以確保您能繼續進行。 以下使用的範例為 SR-SRVCLUSA 與 SR-SRVCLUSB。
建立兩個叢集。 確定叢集名稱為 15 個字元以下。
設定檔案共用見證或雲端見證。
注意
Windows Server 現在包含雲端 (Azure) 見證選項。 您可以選擇此仲裁選項,而不是檔案共用見證。
警告
如需仲裁設定的詳細資訊,請參閱設定和管理仲裁中的見證設定一節。 如需
Set-ClusterQuorum
Cmdlet 的詳細資訊,請參閱 Set-ClusterQuorum。在 Redmond 網站中將一部磁碟新增至叢集 CSV。 若要這樣做,在 [存放裝置] 區段的 [磁碟] 節點中,使用滑鼠右鍵按一下來源磁碟,然後按一下 [新增至叢集共用磁碟區]。
使用設定向外延展檔案伺服器中的指示,在兩個叢集上建立叢集向外延展檔案伺服器
Windows PowerShell 方法
測試建議的叢集並分析結果,以確保您能繼續進行:
Test-Cluster SR-SRV01,SR-SRV02 Test-Cluster SR-SRV03,SR-SRV04
建立叢集 (您必須指定自己的叢集靜態 IP 位址)。 確定每個叢集名稱均為 15 個字元以下︰
New-Cluster -Name SR-SRVCLUSA -Node SR-SRV01,SR-SRV02 -StaticAddress <your IP here> New-Cluster -Name SR-SRVCLUSB -Node SR-SRV03,SR-SRV04 -StaticAddress <your IP here>
在指向共用 (裝載於網域控制站或一些其他獨立伺服器上) 的每個叢集中,設定檔案共用見證或雲端 (Azure) 見證。 例如:
Set-ClusterQuorum -FileShareWitness \\someserver\someshare
注意
Windows Server 現在包含雲端 (Azure) 見證選項。 您可以選擇此仲裁選項,而不是檔案共用見證。
警告
如需仲裁設定的詳細資訊,請參閱設定和管理仲裁中的見證設定一節。 如需
Set-ClusterQuorum
Cmdlet 的詳細資訊,請參閱 Set-ClusterQuorum。使用設定向外延展檔案伺服器中的指示,在兩個叢集上建立叢集向外延展檔案伺服器
步驟 3:使用 Windows PowerShell 設定叢集對叢集複寫
現在您將使用 Windows PowerShell 設定叢集對叢集複寫。 您可以直接在節點,或從包含 Windows Server 遠端伺服器管理工具的遠端系統管理電腦執行下列步驟
在第一個叢集的任何節點上,或從遠端執行 Grant-SRAccess Cmdlet,將第一個叢集的完整存取權授與另一個叢集。 Windows Server 遠端伺服器管理工具
Grant-SRAccess -ComputerName SR-SRV01 -Cluster SR-SRVCLUSB
在第二個叢集的任何節點上,或從遠端執行 Grant-SRAccess Cmdlet,將第二個叢集的完整存取權授與另一個叢集。
Grant-SRAccess -ComputerName SR-SRV03 -Cluster SR-SRVCLUSA
設定叢集對叢集複寫時,要指定來源和目的地磁碟、來源和目的地的記錄檔、來源和目的地叢集名稱,以及記錄檔大小。 您可以在本機伺服器上,或使用遠端管理電腦,執行此命令。
New-SRPartnership -SourceComputerName SR-SRVCLUSA -SourceRGName rg01 -SourceVolumeName c:\ClusterStorage\Volume2 -SourceLogVolumeName f: -DestinationComputerName SR-SRVCLUSB -DestinationRGName rg02 -DestinationVolumeName c:\ClusterStorage\Volume2 -DestinationLogVolumeName f: -LogType Raw
警告
預設記錄檔大小為 8 GB。 根據 Test-SRTopology Cmdlet 的結果,您可能會決定以較高或較低的值來使用 -LogSizeInBytes。
若要取得複寫來源和目的地狀態,請使用 Get-SRGroup 與 Get-SRPartnership,如下所示︰
Get-SRGroup Get-SRPartnership (Get-SRGroup).replicas
判斷複寫進度,如下所示︰
在來源伺服器上,執行下列命令,並檢查 5015、5002、5004、1237、5001 及 2200 事件︰
Get-WinEvent -ProviderName Microsoft-Windows-StorageReplica -max 20
在目的地伺服器上,執行下列命令來查看可顯示建立合作關係的儲存體複本事件。 此事件會說明已複製的位元組數目和所花費的時間。 範例:
Get-WinEvent -ProviderName Microsoft-Windows-StorageReplica | Where-Object {$_.ID -eq "1215"} | Format-List
以下是輸出的範例:
TimeCreated : 4/8/2016 4:12:37 PM ProviderName : Microsoft-Windows-StorageReplica Id : 1215 Message : Block copy completed for replica. ReplicationGroupName: rg02 ReplicationGroupId: {616F1E00-5A68-4447-830F-B0B0EFBD359C} ReplicaName: f:\ ReplicaId: {00000000-0000-0000-0000-000000000000} End LSN in bitmap: LogGeneration: {00000000-0000-0000-0000-000000000000} LogFileId: 0 CLSFLsn: 0xFFFFFFFF Number of Bytes Recovered: 68583161856 Elapsed Time (seconds): 117
或者,複本的目的地伺服器群組會隨時說明待複製的位元組數目,並可透過 PowerShell 進行查詢。 例如:
(Get-SRGroup).Replicas | Select-Object numofbytesremaining
和進度範例 (將不會終止) 一樣:
while($true) { $v = (Get-SRGroup -Name "Replication 2").replicas | Select-Object numofbytesremaining [System.Console]::Write("Number of bytes remaining: {0}`n", $v.numofbytesremaining) Start-Sleep -s 5 }
在目的地叢集中的目的地伺服器上,執行下列命令,並檢查 5009、1237、5001、5015、5005 及 2200 事件,即可了解處理進度。 此序列中應該不會有任何錯誤警告。 其中將會有許多指出進度的 1237 事件。
Get-WinEvent -ProviderName Microsoft-Windows-StorageReplica | FL
注意
複寫時,目的地叢集磁碟永遠會顯示為 [線上 (沒有存取權)]。
步驟 4:管理複寫
現在您即將管理和操作叢集對叢集複寫。 您可以直接在叢集節點,或從包含 Windows Server 遠端伺服器管理工具的遠端系統管理電腦執行下列步驟。
使用 Get-ClusterGroup 或 Failover Cluster Manager,判斷目前的複寫來源與目的地,還有其狀態。 Windows Server 遠端伺服器管理工具
若要測量複寫效能,請在來源和目的地節點上使用 Get-Counter Cmdlet。 計數器名稱如下︰
\Storage Replica Partition I/O Statistics(*)\Number of times flush paused
\Storage Replica Partition I/O Statistics(*)\Number of pending flush I/O
\Storage Replica Partition I/O Statistics(*)\Number of requests for last log write
\Storage Replica Partition I/O Statistics(*)\Avg.Flush Queue Length
\Storage Replica Partition I/O Statistics(*)\Current Flush Queue Length
\Storage Replica Partition I/O Statistics(*)\Number of Application Write Requests
\Storage Replica Partition I/O Statistics(*)\Avg.Number of requests per log write
\Storage Replica Partition I/O Statistics(*)\Avg.App Write Latency
\Storage Replica Partition I/O Statistics(*)\Avg.App Read Latency
\Storage Replica Statistics(*)\Target RPO
\Storage Replica Statistics(*)\Current RPO
\Storage Replica Statistics(*)\Avg.Log Queue Length
\Storage Replica Statistics(*)\Current Log Queue Length
\Storage Replica Statistics(*)\Total Bytes Received
\Storage Replica Statistics(*)\Total Bytes Sent
\Storage Replica Statistics(*)\Avg.Network Send Latency
\Storage Replica Statistics(*)\Replication State
\Storage Replica Statistics(*)\Avg.Message Round Trip Latency
\Storage Replica Statistics(*)\Last Recovery Elapsed Time
\Storage Replica Statistics(*)\Number of Flushed Recovery Transactions
\Storage Replica Statistics(*)\Number of Recovery Transactions
\Storage Replica Statistics(*)\Number of Flushed Replication Transactions
\Storage Replica Statistics(*)\Number of Replication Transactions
\Storage Replica Statistics(*)\Max Log Sequence Number
\Storage Replica Statistics(*)\Number of Messages Received
\Storage Replica Statistics(*)\Number of Messages Sent
如需 Windows PowerShell 中效能計數器的詳細資訊,請參閱 Get-Counter。
若要移動一個網站的複寫方向,請使用 Set-SRPartnership Cmdlet。
Set-SRPartnership -NewSourceComputerName SR-SRVCLUSB -SourceRGName rg02 -DestinationComputerName SR-SRVCLUSA -DestinationRGName rg01
注意
正在進行初始同步處理時,Windows Server 不會阻止角色切換,因為如果您尚未完成初始複寫,即嘗試切換,可能會導致資料遺失。 在完成初始同步處理之前,請勿強制切換方向。
檢查事件記錄檔,以查看複寫方向變更以及復原模式發生的情況,接著予以調解。 然後寫入 IO 就可以寫入新的來源伺服器所擁有的儲存體。 變更複寫方向,將會在先前的來源電腦上封鎖寫入 IO。
注意
複寫時,目的地叢集磁碟永遠會顯示為 [線上 (沒有存取權)]。
若要變更預設的 8 GB 記錄檔大小,請在來源和目的地儲存體複本群組上使用 Set-SRGroup。
重要
預設記錄檔大小為 8 GB。 根據 Test-SRTopology Cmdlet 的結果,您可能會決定以較高或較低的值來使用 -LogSizeInBytes。
若要移除複寫,請在每個叢集上使用 Get-SRGroup、Get-SRPartnership、Remove-SRGroup 及 Remove-SRPartnership。
Get-SRPartnership | Remove-SRPartnership Get-SRGroup | Remove-SRGroup
注意
儲存體複本會卸載目的地磁碟區。 這是原廠設定。