獨立 Service Fabric 中的定期備份和還原
Service Fabric 是開發及管理可靠分散式雲端應用程式的平台。 其同時支援無狀態和具狀態微服務。 具狀態服務可以將重要的資料保留在單一要求或交易之外。 如果具狀態服務關閉或遺失資料,可能需要從最近的備份還原,才能繼續正常運作。
Service Fabric 會將狀態複寫至多個節點,以確保服務具有高可用性。 即使叢集內的一個節點失敗,服務仍繼續可供使用。 不過,在某些情況下,仍然建議您讓服務資料能夠穩定可靠地面對更廣泛的失敗狀況。
例如,服務可能需要備份其資料,才能在下列案例中提供保護:
- 永久遺失整個 Service Fabric 叢集。
- 永久遺失多數的服務分割區複本
- 不小心刪除或損毀狀態的系統管理錯誤。 例如,具備足夠權限的系統管理員錯誤地刪除服務。
- 服務中造成資料損毀的錯誤。 例如,當服務程式碼升級而開始將錯誤資料寫入「可靠的集合」時,就可能發生此情況。 在這種情況下,可能必須將程式碼和資料還原成先前的狀態。
- 離線資料處理。 對於獨立於服務來產生資料的商業智慧,離線處理資料相當方便。
Service Fabric 提供內建的 API 來執行時間點備份與還原。 應用程式開發人員可以使用這些 API 來定期備份服務的狀態。 此外,如果服務管理員想要在特定時間 (例如在升級應用程式之前) 從服務外部觸發備份,開發人員就必須從服務將備份 (和還原) 公開為 API。 維護備份是這之外的一筆額外成本。 例如,您可以每半小時建立 5 個增量備份,接著再建立一個完整備份。 在建立完整備份之後,您便可以刪除先前的增量備份。 這個方法需要額外的程式碼,而會造成在應用程式開發期間產生額外的成本。
對於管理分散式應用程式,以及防止資料遺失或服務長期中斷來說,定期備份應用程式資料是一項基本需求。 Service Fabric 提供一項選用的備份與還原服務,可讓您在不撰寫任何額外程式碼的情況下,設定具狀態 Reliable Services (包括動作項目服務) 的定期備份。 它也可以協助還原先前建立的備份。
Service Fabric 提供一組 API,可實現下列和定期備份與復原功能相關的功能:
- 排定可靠具狀態服務和 Reliable Actors 的定期備份,並支援將備份上傳至 (外部) 儲存體位置。 支援的儲存位置
- Azure 儲存體
- 檔案共用 (內部部署)
- 列舉備份
- 觸發分割區未計畫的備份
- 使用先前的備份來還原分割區
- 暫時暫停備份
- 備份的保留管理 (即將推出)
必要條件
具有 Fabric 6.4 版或更新版本的 Service Fabric 叢集。 如需下載所需套件的步驟,請參閱這篇文章。
用於加密祕密 (連線至儲存體以儲存備份時所需) 的 X.509 憑證。 若要了解如何取得或建立自我簽署的 X.509 憑證,請參閱這篇文章。
使用 Service Fabric SDK 3.0 版或更新版本來建置的 Service Fabric 可靠具狀態應用程式。 針對以 .Net Core 2.0 為目標的應用程式,應該使用 Service Fabric SDK 3.1 版或更新版本來建置應用程式。
安裝 Microsoft.ServiceFabric.PowerShell.Http 模組以進行設定呼叫。
Install-Module -Name Microsoft.ServiceFabric.PowerShell.Http -AllowPrerelease
注意
如果 PowerShellGet 版本小於1.6.0,您將需要更新以新增對 -AllowPrerelease 旗標的支援:
Install-Module -Name PowerShellGet -Force
- 使用 Microsoft.ServiceFabric.PowerShell.Http 模組進行任何設定要求之前,請先使用
Connect-SFCluster
命令來確定叢集已連線。
Connect-SFCluster -ConnectionEndpoint 'https://mysfcluster.southcentralus.cloudapp.azure.com:19080' -X509Credential -FindType FindByThumbprint -FindValue '1b7ebe2174649c45474a4819dafae956712c31d3' -StoreLocation 'CurrentUser' -StoreName 'My' -ServerCertThumbprint '1b7ebe2174649c45474a4819dafae956712c31d3'
啟用備份與還原服務
首先,您必須在叢集啟用「備份與還原服務」。 取得您想要部署之叢集的範本。 您可以使用範例範本。 請使用下列步驟來啟用「備份與還原服務」:
檢查叢集設定檔中的
apiversion
是否已設定為10-2017
,如果不是,請更新它,如下列程式碼片段所示:{ "apiVersion": "10-2017", "name": "SampleCluster", "clusterConfigurationVersion": "1.0.0", ... }
現在,在
properties
區段底下新增下列addonFeatures
區段來啟用「備份與還原服務」,如下列程式碼片段所示:"properties": { ... "addonFeatures": ["BackupRestoreService"], "fabricSettings": [ ... ] ... }
設定用於加密認證的 X.509 憑證。 這很重要,可確保所提供來連線至儲存體的認證 (如果有的話) 會先經過加密再進行保存。 在
fabricSettings
區段底下新增下列BackupRestoreService
區段來設定加密憑證,如下列程式碼片段所示:"properties": { ... "addonFeatures": ["BackupRestoreService"], "fabricSettings": [{ "name": "BackupRestoreService", "parameters": [ { "name": "SecretEncryptionCertThumbprint", "value": "[Thumbprint]" }, { "name": "SecretEncryptionCertX509StoreName", "value": "My" } ] }] ... }
注意
[指紋] 必須由要用來加密的有效憑證指紋取代。
在您更新叢集設定檔以反映先前的變更之後,請套用這些變更,然後讓部署/升級完成。 一旦完成,備份與還原服務就會在您的叢集中執行。 此服務的 URI 是
fabric:/System/BackupRestoreService
,此服務可能位於 Service Fabric 總管中的系統服務區段底下。
啟用可靠具狀態服務和 Reliable Actors 的定期備份
以下步驟將逐步解說如何啟用可靠具狀態服務和 Reliable Actors 的定期備份。 這些步驟假設
- 叢集是使用備份和還原 service_ 進行設定。
- 叢集上已部署可靠具狀態服務。 基於本快速入門指南的目的,應用程式 URI 是
fabric:/SampleApp
,而屬於此應用程式的可靠具狀態服務 URI 是fabric:/SampleApp/MyStatefulService
。 此服務是使用單一分割區的,而分割區識別碼是23aebc1e-e9ea-4e16-9d5c-e91a614fefa7
。
建立備份原則
第一個步驟是建立備份原則。 此原則應包含備份排程、備份資料的目標儲存體、原則名稱、觸發完整備份之前允許的增量備份數目上限,以及備份儲存體的保留原則。
針對備份儲存體,請建立檔案共用,然後將此檔案共用的 ReadWrite 存取權授與所有 Service Fabric 節點電腦。 此範例假設 StorageServer
上有名為 BackupStore
的共用。
使用 Microsoft.ServiceFabric.PowerShell.Http 模組的 PowerShell
New-SFBackupPolicy -Name 'BackupPolicy1' -AutoRestoreOnDataLoss $true -MaxIncrementalBackups 20 -FrequencyBased -Interval 00:15:00 -FileShare -Path '\\StorageServer\BackupStore' -Basic -RetentionDuration '10.00:00:00'
使用 PowerShell 進行 REST 呼叫
執行下列 PowerShell 指令碼,叫用必要的 REST API 來建立新原則。
$ScheduleInfo = @{
Interval = 'PT15M'
ScheduleKind = 'FrequencyBased'
}
$StorageInfo = @{
Path = '\\StorageServer\BackupStore'
StorageKind = 'FileShare'
}
$RetentionPolicy = @{
RetentionPolicyType = 'Basic'
RetentionDuration = 'P10D'
}
$BackupPolicy = @{
Name = 'BackupPolicy1'
MaxIncrementalBackups = 20
Schedule = $ScheduleInfo
Storage = $StorageInfo
RetentionPolicy = $RetentionPolicy
}
$body = (ConvertTo-Json $BackupPolicy)
$url = "http://localhost:19080/BackupRestore/BackupPolicies/$/Create?api-version=6.4"
Invoke-WebRequest -Uri $url -Method Post -Body $body -ContentType 'application/json'
使用 Service Fabric Explorer
在 Service Fabric Explorer 中,瀏覽至 [備份] 索引標籤,然後選取 [動作] 和 [建立備份原則]。
填寫資訊。 針對獨立叢集,應該選取 [檔案共用]。
啟用定期備份
在定義滿足應用程式資料保護需求的原則之後,應該將該備份原則與應用程式建立關聯。 視需求而定,備份原則可以與應用程式、服務或分割區相關聯。
使用 Microsoft.ServiceFabric.PowerShell.Http 模組的 PowerShell
Enable-SFApplicationBackup -ApplicationId 'SampleApp' -BackupPolicyName 'BackupPolicy1'
使用 PowerShell 進行 REST 呼叫
請執行下列 PowerShell 指令碼叫用必要的 REST API,以將在上述步驟中所建立名為 BackupPolicy1
的備份原則與應用程式 SampleApp
建立關聯。
$BackupPolicyReference = @{
BackupPolicyName = 'BackupPolicy1'
}
$body = (ConvertTo-Json $BackupPolicyReference)
$url = "http://localhost:19080/Applications/SampleApp/$/EnableBackup?api-version=6.4"
Invoke-WebRequest -Uri $url -Method Post -Body $body -ContentType 'application/json'
使用 Service Fabric Explorer
請確定已在叢集上啟用 BackupRestoreService。
開啟 Service Fabric Explorer。
選取應用程式並移至 [備份] 區段。 按一下 [備份動作]。
按一下 [啟用/更新應用程式備份]。
最後,選取所需的原則,然後選取 [啟用備份]。
確認定期備份能夠運作
啟用應用程式的備份之後,所有屬於應用程式底下可靠具狀態服務和 Reliable Actors 的分割區,就會依據關聯的備份原則開始定期進行備份。
列出備份
您可以使用 GetBackups API,以列舉屬於應用程式可靠具狀態服務和 Reliable Actors 的所有分割區相關備份。 視需求而定,可以列舉應用程式、服務或分割區的備份。
使用 Microsoft.ServiceFabric.PowerShell.Http 模組的 PowerShell
Get-SFApplicationBackupList -ApplicationId WordCount
使用 PowerShell 進行 REST 呼叫
請執行下列 PowerShell 指令碼來叫用 HTTP API,以列舉針對 SampleApp
應用程式內所有分割區建立的備份。
$url = "http://localhost:19080/Applications/SampleApp/$/GetBackups?api-version=6.4"
$response = Invoke-WebRequest -Uri $url -Method Get
$BackupPoints = (ConvertFrom-Json $response.Content)
$BackupPoints.Items
上述執行的範例輸出:
BackupId : d7e4038e-2c46-47c6-9549-10698766e714
BackupChainId : d7e4038e-2c46-47c6-9549-10698766e714
ApplicationName : fabric:/SampleApp
ServiceName : fabric:/SampleApp/MyStatefulService
PartitionInformation : @{LowKey=-9223372036854775808; HighKey=9223372036854775807; ServicePartitionKind=Int64Range; Id=23aebc1e-e9ea-4e16-9d5c-e91a614fefa7}
BackupLocation : SampleApp\MyStatefulService\23aebc1e-e9ea-4e16-9d5c-e91a614fefa7\2018-04-01 19.39.40.zip
BackupType : Full
EpochOfLastBackupRecord : @{DataLossNumber=131670844862460432; ConfigurationNumber=8589934592}
LsnOfLastBackupRecord : 2058
CreationTimeUtc : 2018-04-01T19:39:40Z
FailureError :
BackupId : 8c21398a-2141-4133-b4d7-e1a35f0d7aac
BackupChainId : d7e4038e-2c46-47c6-9549-10698766e714
ApplicationName : fabric:/SampleApp
ServiceName : fabric:/SampleApp/MyStatefulService
PartitionInformation : @{LowKey=-9223372036854775808; HighKey=9223372036854775807; ServicePartitionKind=Int64Range; Id=23aebc1e-e9ea-4e16-9d5c-e91a614fefa7}
BackupLocation : SampleApp\MyStatefulService\23aebc1e-e9ea-4e16-9d5c-e91a614fefa7\2018-04-01 19.54.38.zip
BackupType : Incremental
EpochOfLastBackupRecord : @{DataLossNumber=131670844862460432; ConfigurationNumber=8589934592}
LsnOfLastBackupRecord : 2237
CreationTimeUtc : 2018-04-01T19:54:38Z
FailureError :
BackupId : fc75bd4c-798c-4c9a-beee-e725321f73b2
BackupChainId : d7e4038e-2c46-47c6-9549-10698766e714
ApplicationName : fabric:/SampleApp
ServiceName : fabric:/SampleApp/MyStatefulService
PartitionInformation : @{LowKey=-9223372036854775808; HighKey=9223372036854775807; ServicePartitionKind=Int64Range; Id=23aebc1e-e9ea-4e16-9d5c-e91a614fefa7}
BackupLocation : SampleApp\MyStatefulService\23aebc1e-e9ea-4e16-9d5c-e91a614fefa7\2018-04-01 20.09.44.zip
BackupType : Incremental
EpochOfLastBackupRecord : @{DataLossNumber=131670844862460432; ConfigurationNumber=8589934592}
LsnOfLastBackupRecord : 2437
CreationTimeUtc : 2018-04-01T20:09:44Z
FailureError :
使用 Service Fabric Explorer
若要在 Service Fabric Explorer 中檢視備份,請瀏覽至分割區,然後選取 [備份] 索引標籤。
限制 / 注意事項
- Service Fabric PowerShell Cmdlet 處於預覽模式。
- 不支援 Linux 上的 Service Fabric 叢集。