伺服器對伺服器儲存體複寫
您可以使用儲存體複本設定兩部伺服器來同步處理資料,讓每個都有相同磁碟區的相同複本。 本主題提供這種伺服器對伺服器複寫組態的一些背景,以及如何設定和管理環境。
若要管理儲存體複本,您可以使用 Windows Admin Center 或 PowerShell。
以下是在 Windows Admin Center 中使用儲存體複本的概觀影片。
必要條件
- Active Directory Domain Services 樹系 (不需要執行 Windows Server 2016)。
- 兩部執行 Windows Server 2019 或 Windows Server 2016 Datacenter Edition 的伺服器。 如果您要執行 Windows Server 2019,而且確定只複寫大小上限為 2 TB 的單一磁碟區,則可以改用 Standard Edition。
- 使用 SAS JBOD、光纖通道 SAN、iSCSI 目標,或本機 SCSI/SATA 儲存體的兩組儲存體。 儲存體應包含 HDD 和 SSD 兩者混合的媒體。 您必須設定每組儲存體只能供各自的伺服器使用,不得共用存取。
- 每組存放裝置必須允許建立至少兩個虛擬磁碟,一個供複寫的資料使用,另一個供記錄檔使用。 實體存放裝置的所有資料磁碟上,必須都要有相同的磁區大小。 實體存放裝置的所有記錄檔磁碟上,必須都要有相同的磁區大小。
- 每部伺服器上至少要有一個乙太網路/TCP 連線,以進行同步複寫,但最好是 RDMA。
- 適當的防火牆與路由器規則,以允許在所有節點之間提供 ICMP、SMB (連接埠 445,若為 SMB 直接傳輸,需再加上 5445) 以及 WS-MAN (連接埠 5985) 雙向流量。
- 針對同步複寫,伺服器間的網路頻寬必須足以容納您的 IO 寫入工作負載,以及平均 =5ms 的來回延遲。 非同步複寫沒有延遲建議。
如果您要在內部部署伺服器與 Azure VM 之間複寫,則必須在內部部署伺服器與 Azure VM 之間建立網路連結。 若要這樣做,請使用 Express Route (一種站對站 VPN 閘道連線),或在 Azure VM 中安裝 VPN 軟體,以將其與您的內部部署網路連線。 - 複寫的儲存體不可位於包含 Windows 作業系統資料夾的磁碟機上。
重要
在此案例中,每部伺服器都應該位於不同的實體或邏輯網站中。 每部伺服器都必須能夠透過網路,彼此進行通訊。
這其中許多需求都可以使用 Test-SRTopology cmdlet
來判斷。 如果您至少在一部伺服器上安裝儲存體複本或儲存體複本管理工具功能,便可存取此工具。 只要安裝此 Cmdlet 即可,不需要將儲存體複本設定為使用此工具。 詳細資訊收錄於下列步驟。
Windows Admin Center 需求
若要同時使用儲存體複本和 Windows Admin Center,您需要下列項目:
系統 | 作業系統 | 必須用於 |
---|---|---|
兩部伺服器 (任何內部部署硬體、VM 和雲端 VM (包括 Azure VM) 的混合) |
Windows Server 2019、Windows Server 2016 或 Windows Server (半年通道) | 儲存體複本 |
一部 PC | Windows 10 | Windows Admin Center |
注意
目前您無法在伺服器上使用 Windows Admin Center 來管理儲存體複本。
詞彙
本逐步解說使用下列環境做為範例︰
兩部伺服器,名為 SR SRV05 和 SR SRV06。
代表示兩個不同資料中心的一對邏輯「網站」,一個名為 Redmond,而另一個名 Bellevue。
圖 1:伺服器對伺服器複寫
步驟 1:在 PC 上安裝和設定 Windows Admin Center
如果您要使用 Windows Admin Center 來管理儲存體複本,則請使用下列步驟來準備您的 PC,以管理儲存體複本。
下載和安裝 Windows Admin Center。
下載和安裝遠端伺服器系統管理工具。
- 如果您要使用 Windows 10 1809 版或更新版本,則請從 [功能隨選安裝] 中安裝 [RSAT:Windows PowerShell 的儲存體複本模組]。
以系統管理員身分開啟 PowerShell 工作階段,方法是選取 [開始] 按鈕,並輸入 [PowerShell],再以滑鼠右鍵按一下 [Windows PowerShell],然後選取 [以系統管理員身分執行]。
輸入下列命令,以在本機電腦上啟用 WS-Management 通訊協定,並在用戶端上設定預設遠端管理設定。
winrm quickconfig
輸入 [Y],以啟用 WinRM 服務,並啟用 WinRM 防火牆例外狀況。
步驟 2:佈建作業系統、功能、角色、儲存體和網路
在安裝類型為 [Windows Server (桌面體驗)] 的兩個伺服器節點上,安裝 Windows Server。
若要使用透過 ExpressRoute 連線至您網路的 Azure VM,請參閱透過 ExpressRoute 新增連線至您網路的 Azure VM。
注意
從 Windows Admin Center 1910 版開始,您可以在 Azure 中自動設定目的地伺服器。 如果您選擇該選項,則請在來源伺服器上安裝 Windows Server,然後跳至步驟 3:設定伺服器對伺服器複寫。
新增網路資訊,並將伺服器加入與 Windows 10 管理 PC (若您要使用) 相同的網域,然後重新啟動伺服器。
注意
從此時開始,一律要以所有伺服器上內建系統管理員群組成員的網域使用者身分登入。 請務必記住,在圖形化伺服器安裝或在 Windows 10 電腦上執行時,一開始要提升 PowerShell 和 CMD 命令提示字元的權限。
將第一組 JBOD 存放裝置機箱、iSCSI 目標、FC SAN 或本機固定式磁碟 (DAS) 存放裝置連線至 Redmond 網站中的伺服器。
將第二組存放裝置連線至 Bellevue 網站中的伺服器。
若適當,在兩個節點上安裝最新的廠商儲存體和機箱韌體與驅動程式、最新的廠商 HBA 驅動程式、最新的廠商 BIOS/UEFI 韌體、最新的廠商網路驅動程式,以及最新的主機板晶片組驅動程式。 視需要重新啟動節點。
注意
如需設定共用儲存體和網路硬體,請參閱硬體廠商的文件。
確定伺服器的 BIOS/UEFI 設定能提供高效能,例如停用 C-State、設定 QPI 速度、啟用 NUMA,以及設定最高的記憶體頻率。 確定將 Windows Server 中的電源管理設定為 [高效能]。 視需要重新啟動。
如下所示設定角色:
Windows Admin Center 方法
- 在 [Windows Admin Center] 中,導覽至 [伺服器管理員],然後選取其中一部伺服器。
- 瀏覽至角色 & 功能。
- 選取 [功能] > [儲存體複本],然後按一下 [安裝]。
- 在另一個伺服器上重複進行。
伺服器管理員方法
執行 ServerManager.exe,並新增所有伺服器節點以建立伺服器群組。
在每個節點上安裝 [檔案伺服器] 和 [儲存體複本] 角色和功能,然後予以重新啟動。
Windows PowerShell 方法
在 SR-SRV06 或遠端管理電腦上,於 Windows PowerShell 主控台執行下列命令,以安裝所需的功能與角色,並予以重新啟動:
$Servers = 'SR-SRV05','SR-SRV06' $Servers | ForEach { Install-WindowsFeature -ComputerName $_ -Name Storage-Replica,FS-FileServer -IncludeManagementTools -restart }
如需這些步驟的詳細資訊,請參閱安裝或解除安裝角色、角色服務或功能
如下所示設定儲存體:
重要
- 您必須在每個機箱上建立兩個磁碟區︰一個供資料使用,而另一個供記錄檔使用。
- 記錄檔和資料磁碟必須初始化為 GPT,而非多位元率 (MBR)。
- 這兩個資料磁碟區的大小必須相同。
- 這兩個記錄檔磁碟區的大小應該相同。
- 所有複寫的資料磁碟都必須有相同的磁區大小。
- 所有記錄檔磁碟都必須有相同的磁區大小。
- 記錄檔磁碟區應該使用 Flash 架構的儲存體,例如 SSD。 Microsoft 建議記錄儲存體比資料儲存體更快。 記錄磁碟區絕對不能用於其他工作負載。
- 資料磁碟可以使用 HDD、SSD 或階層式組合,而且可以使用鏡像或同位空間,或是 RAID 1 或 10、RAID 5 或 RAID 50。
- 記錄磁碟區預設必須至少有 9 GB,而且根據記錄需求,可能會更大或更小。
- 檔案伺服器角色只有在操作 Test-SRTopology 時才需要,因為它會開啟必要的防火牆連接埠進行測試。
針對 JBOD 機箱:
請確定每部伺服器只能看到該網站的儲存體機箱,同時已正確設定 SAS 連線。
遵循在獨立伺服器上部署儲存空間中提供的步驟 1-3,使用 Windows PowerShell 或伺服器管理員,使用儲存空間佈建儲存體。
針對 iSCSI 儲存體:
請確定每個叢集只能看到該網站的存放裝置機箱。 如果使用 iSCSI,您應該使用一張以上的網路介面卡。
使用廠商的文件來佈建儲存體。 如果使用 Windows iSCSI 目標,請參閱 iSCSI 目標區塊儲存體,作法。
針對 FC SAN 儲存體:
請確定每個叢集只能看到該網站的儲存體機箱,同時您已將主機適當地分區。
使用廠商的文件來佈建儲存體。
針對本機固定磁碟儲存體:
請確定儲存體未包含系統磁碟區、分頁檔或傾印檔案。
使用廠商的文件來佈建儲存體。
啟動 Windows PowerShell,然後使用 Test-SRTopology Cmdlet 來判斷您是否符合所有儲存體複本需求。 您可以在僅查看需求的模式中,使用此 Cmdlet 進行快速測試,還可以在評估長時間執行效能的模式中使用。
例如,若要驗證建議的節點,其中每一個都有 F: 與 G: 磁碟區,且要執行測試長達 30 分鐘:
MD c:\temp Test-SRTopology -SourceComputerName SR-SRV05 -SourceVolumeName f: -SourceLogVolumeName g: -DestinationComputerName SR-SRV06 -DestinationVolumeName f: -DestinationLogVolumeName g: -DurationInMinutes 30 -ResultPath c:\temp
重要
在指定的來源磁碟區上,若在評估期間使用的測試伺服器沒有任何寫入 IO 負載,請考慮新增工作負載,否則不會產生有用的報告。 您應該使用和實際執行類似的工作負載來測試,才能看出實際的數字與建議的記錄檔大小。 或者,只要在測試期間,將一些檔案複製到來源磁碟區,或下載並執行 DISKSPD 以產生寫入 IO 即可。 例如,會寫入 D: 磁碟區長達十分鐘的少量 IO 工作負載範例︰
Diskspd.exe -c1g -d600 -W5 -C5 -b8k -t2 -o2 -r -w5 -i100 -j100 d:\test
檢查 TestSrTopologyReport.html 報告 (如圖 2 所示),確定您符合儲存體複本需求。
圖 2:儲存體複寫拓撲報告
步驟 3:設定伺服器對伺服器複寫
使用 Windows Admin Center
新增來源伺服器。
- 選取新增按鈕。
- 選取 [新增伺服器連線]。
- 輸入伺服器的名稱,然後選取 [提交]。
在 [所有連線] 頁面上,選取來源伺服器。
從 [工具] 面板中,選取 [儲存體複本]。
選取 [新增],以建立新的合作關係。 建立新的 Azure VM,以用作合作關係的目的地:
- 在 [複寫至另一部伺服器] 下方,選取 [使用新的 Azure VM],然後選取 [下一步]。 如果您看不到此選項,則請確定您正在使用 Windows Admin Center 1910 版或更新版本。
- 指定來源伺服器資訊和複寫群組名稱,然後選取 [下一步]。
這會開始一個程序,而此程序會自動選取 Windows Server 2019 或 Windows Server 2016 Azure VM 作為移轉來源的目的地。 儲存體移轉服務建議可符合您來源的 VM 大小,但您可以選取 [查看所有大小] 以將其覆寫。 庫存資料用來自動設定受管理磁碟和其檔案系統,以及將新的 Azure VM 加入 Active Directory 網域。 - Windows Admin Center 建立 Azure VM 之後,請提供複寫群組名稱,然後選取 [建立]。 Windows Admin Center 接著會開始一般儲存體複本初始同步處理程序,以開始保護您的資料。
以下影片顯示如何使用儲存體複本以移轉至 Azure VM。
提供合作關係的詳細資料,然後選取 [建立] (如圖 3 所示)。
圖 3:建立新的合作關係
注意
從 Windows Admin Center 中的儲存體複本移除合作關係並不會移除複寫群組名稱。
使用 Windows PowerShell
現在,您將使用 Windows PowerShell 設定伺服器對伺服器複寫。 您必須直接在節點上或從包含 Windows Server 遠端伺服器系統管理工具的遠端管理電腦中執行下列所有步驟。
請確定您要以系統管理員身分使用提升權限的 PowerShell 主控台。
設定伺服器對伺服器複寫時,要指定來源和目的地磁碟、來源和目的地記錄檔、來源和目的地節點,以及記錄檔大小。
New-SRPartnership -SourceComputerName sr-srv05 -SourceRGName rg01 -SourceVolumeName f: -SourceLogVolumeName g: -DestinationComputerName sr-srv06 -DestinationRGName rg02 -DestinationVolumeName f: -DestinationLogVolumeName g: -LogType Raw
輸出:
DestinationComputerName : SR-SRV06 DestinationRGName : rg02 SourceComputerName : SR-SRV05 PSComputerName :
重要
預設記錄檔大小為 8 GB。 根據
Test-SRTopology
Cmdlet 的結果,您可能會決定以較高或較低的值來使用 -LogSizeInBytes。若要取得複寫來源和目的地狀態,請使用
Get-SRGroup
和Get-SRPartnership
,如下所示:Get-SRGroup Get-SRPartnership (Get-SRGroup).replicas
輸出:
CurrentLsn : 0 DataVolume : F:\ LastInSyncTime : LastKnownPrimaryLsn : 1 LastOutOfSyncTime : NumOfBytesRecovered : 37731958784 NumOfBytesRemaining : 30851203072 PartitionId : c3999f10-dbc9-4a8e-8f9c-dd2ee6ef3e9f PartitionSize : 68583161856 ReplicationMode : synchronous ReplicationStatus : InitialBlockCopy PSComputerName :
判斷複寫進度,如下所示︰
在來源伺服器上,執行下列命令,並檢查 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"} | fl
以下是一些範例輸出:
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 (ms): 117
注意
儲存體複本會將目的地磁碟區與其磁碟機代號或掛接點卸載。 這是原廠設定。
或者,複本的目的地伺服器群組會隨時說明待複製的位元組數目,並可透過 PowerShell 進行查詢。 例如:
(Get-SRGroup).Replicas | Select-Object numofbytesremaining
和進度範例 (將不會終止) 一樣:
while($true) { $v = (Get-SRGroup -Name "RG02").replicas | Select-Object numofbytesremaining [System.Console]::Write("Number of bytes remaining: {0}`r", $v.numofbytesremaining) Start-Sleep -s 5 }
在目的地伺服器上,執行下列命令,並檢查 5009、1237、5001、5015、5005 及 2200 事件,以了解處理進度。 此序列中應該不會有任何錯誤警告。 其中將會有許多指出進度的 1237 事件。
Get-WinEvent -ProviderName Microsoft-Windows-StorageReplica | FL
步驟 4:管理複寫
現在您將會管理與操作伺服器對伺服器複寫的基礎結構。 您連線直接在節點上或從包含 Windows Server 遠端伺服器系統管理工具的遠端管理電腦中執行下列所有步驟。
使用
Get-SRPartnership
和Get-SRGroup
來判斷目前的複寫來源與目的地及其狀態。若要測量複寫效能,請在來源和目的地節點上使用
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-srv06 -SourceRGName rg02 -DestinationComputerName sr-srv05 -DestinationRGName rg01
警告
正在進行初始同步處理時,Windows Server 會防止角色切換,因為如果您在允許初始複寫完成之前嘗試切換,則可能會導致資料遺失。 除非初始同步處理完成,否則請不要強制切換方向。
檢查事件記錄檔,以查看複寫方向變更以及復原模式發生的情況,接著予以調解。 然後寫入 IO 就可以寫入新的來源伺服器所擁有的儲存體。 變更複寫方向,將會在先前的來源電腦上封鎖寫入 IO。
若要移除複寫,在任何節點上使用
Get-SRGroup
、Get-SRPartnership
、Remove-SRGroup
及Remove-SRPartnership
。 請確定您僅在目前的複寫來源上執行Remove-SRPartnership
Cmdlet,而不是在目的地伺服器上執行。 在兩部伺服器上執行Remove-SRGroup
。 例如,若要從兩部伺服器移除所有複寫︰Get-SRPartnership Get-SRPartnership | Remove-SRPartnership Get-SRGroup | Remove-SRGroup
以儲存體複本取代 DFS 複寫
許多 Microsoft 客戶會將 DFS 複寫部署為非結構化使用者資料 (例如主資料夾和部門共用) 的嚴重損壞修復解決方案。 DFS 複寫已隨附於 Windows Server 2003 R2 和所有更新版本的作業系統中,並在低頻寬網路上運作,這會吸引具有許多節點的高延遲及低變化環境。 不過,DFS 複寫如同資料複寫解決方案,有一些值得注意的限制︰
- 它不會複寫正在使用或已開啟的檔案。
- 它不會同步複寫。
- 其非同步複寫延遲可能是好幾分鐘,好幾小時,甚至好幾天。
- 它所依賴的資料庫在電源中斷後可能需要冗長的一致性檢查。
- 這通常設定為多重主機,以允許雙向流動的變更,進而可能覆寫較新的資料。
儲存體複本沒有這些限制。 不過,它所擁有的一些限制可能會使其在部分環境中變得比較不吸引人︰
- 它只允許磁碟區之間的一對一複寫。 這可能會複寫多部伺服器之間的不同磁碟區。
- 雖然其支援非同步複寫,但不是針對低頻寬、高延遲網路所設計。
- 它不允許使用者於正在複寫時存取目的地上的受保護資料
如果這些不會成為裹足不前的因素,儲存體複本可讓您使用這個較新的技術取代 DFS 複寫伺服器。 高階程序為︰
在兩部伺服器上安裝 Windows Server,並設定您的儲存體。 這可能表示升級一組現有的伺服器或全新安裝。
請確定您想要複寫的任何資料存在於一個或多個資料磁碟區上,而不是在 C: 磁碟機上。 a. 您也可以使用備份或檔案複本,在另一部伺服器上植入資料以節省時間,並使用精簡佈建的儲存體。 與 DFS 複寫不同的是,不需要使類似中繼資料的安全性完全相符。
共用來源伺服器上的資料,並讓它能夠透過 DFS 命名空間進行存取。 為確保伺服器名稱變更為嚴重損壞網站中的伺服器名稱時仍然可以存取該伺服器,此作業相當重要。 a. 您可以在正常作業期間將無法使用的目的地伺服器上建立相符的共用。 請不要在「DFS 命名空間」命名空間中新增目的地伺服器,否則,請確定已停用其所有資料夾目標。
啟用儲存體複本的複寫,並完成初始同步。複寫可以使用同步或非同步方式進行。 a. 不過,建議使用同步方式,才能保證目的地伺服器上的 IO 資料一致性。 b. 我們強烈建議啟用 [磁碟區陰影複製],並使用 VSSADMIN 或您選擇的其他工具,定期製作快照。 這樣會保證應用程式將其資料檔案一致清除至磁碟。 萬一發生嚴重損壞,您可以在可能已使用非同步方式部分複寫的目的地伺服器上,復原快照中的檔案。 快照集複寫及檔案。
正常運作,直到發生嚴重損壞為止。
切換目的地伺服器成為新的來源,向使用者呈現其複寫的磁碟區。
如果使用同步複寫,除非使用者所使用的應用程式在失去來源伺服器期間寫入沒有交易保護的資料 (這與複寫無關),否則將不需要還原任何資料。 如果使用非同步複寫,比較需要使用 VSS 快照掛接,但請考慮在所有情況下都使用 VSS,讓應用程式取得一致的快照。
新增伺服器和其共用作為「DFS 命名空間」資料夾目標。
接著,使用者可以存取其資料。
注意
嚴重損壞修復規劃是一個複雜的主題,需要非常注意細節。 強烈建議您建立年度即時容錯移轉步驟 Runbook 和效能。 當實際的災害來襲時,混亂將會主導一切,而且可能無法連絡到有經驗的人員。
透過 ExpressRoute 新增連線至您網路的 Azure VM
在 Azure 入口網站中建立 ExpressRoute。
核准 ExpressRoute 之後,會將資源群組新增至訂閱 - 導覽至 [資源群組] 來檢視這個新的群組。 記下虛擬網路名稱。圖 4:與 ExpressRoute 相關聯的資源 - 記下虛擬網路名稱
新增網路安全性群組。 建立時,請選取與您所建立 ExpressRoute 相關聯的訂閱識別碼,也請選取您剛才建立的資源群組。
將您需要的任何輸入和輸出安全性規則清單新增至網路安全性群組。 例如,您可能想要允許遠端桌面存取 VM。使用下列設定來建立 Azure VM (如圖 5 所示):
- 公用 IP 位址:無
- 虛擬網路:從使用 ExpressRoute 所新增的資源群組中,選取您記下的虛擬網路。
- 網路安全性群組 (防火牆):選取您先前所建立的網路安全性群組。 圖 5:選取 ExpressRoute 網路設定時建立 VM
建立 VM 之後,請參閱步驟 2:佈建作業系統、功能、角色、儲存體和網路。