obshellを使用して、OceanBaseデータベースのテナントレベルの復旧を開始する方法は2種類あります:
APIを呼び出して復旧を開始する
obshellコマンドを使用して復旧を開始する
この記事では、3レプリカのOceanBaseクラスタを例に、obshellを使用してテナントレベルの復旧を開始する方法について説明します。
前提条件
OceanBaseクラスタがobshellで運用保守されており、詳細な判断方法と引き継ぎ操作については非obshellデプロイメントクラスタの引き継ぎを参照してください。
OceanBaseクラスタ内のすべてのOBServerノードおよびobshellが正常に稼働しています。
デプロイメントモード
本記事では、3台のマシンを使用する場合の状況を以下に示します(obshellはデフォルトポート2886を使用します):
| ロール | マシン | 備考 |
|---|---|---|
| OBServerノード | 10.10.10.1 | OceanBaseデータベースzone1 |
| OBServerノード | 10.10.10.2 | OceanBaseデータベースzone2 |
| OBServerノード | 10.10.10.3 | OceanBaseデータベースzone3 |
APIを使用した復元
説明
obshellは呼び出されるAPIに対してセキュリティ検証を行います。そのため、APIを呼び出すたびに、APIハイブリッド暗号化の記事で示されているように、要求を事前に暗号化し、curlコマンドに暗号化された要求ヘッダー(${request_headers})と要求ボディ(${request_body})を設定する必要があります。
ステップ1:テナントレベルの復旧を開始する
任意のobshellの/api/v1/tenant/restoreインターフェースを呼び出すことで、テナントレベルの復旧を開始できます。
コマンドラインで対応するAPIインターフェースを呼び出す方法については、テナントの復旧を開始するを参照してください。このインターフェースは非同期タスクを作成します。タスクの進捗状況を確認する方法については、タスクの詳細情報を取得するを参照してください。タスクが完了するまで待機すると、復旧が終了します。
[admin@test001 ~]$ curl -H "Content-Type: application/json" -H 'X-OCS-Header:${request_headers}' -X POST -d '${request_body}' http://10.10.10.1:2886//api/v1/tenant/restore
暗号化前のリクエストボディの内容は次のとおりです:
{
"data_backup_uri": "file:///data/backup/data",
"restore_tenant_name": "tenant1",
"zone_list":
[
{
"name": "zone1",
"unit_config_name": "unit1",
"unit_num": 1
}
],
"archive_log_uri": "file:///data/backup/archive"
}
obshell-sdk-pythonを使用して対応するAPIメソッドをリクエストする方法については、テナントの復旧を開始するを参照してください。
...
client = ClientSet("10.10.10.1", 2886, PasswordAuth("****"))
client.v1.post_tenant_restore_sync(
data_backup_uri="file:///data/backup/data",
tenant_name="tenant1",
zone_list=[
tenant.ZoneParam("zone1", "unit1",1),
],
archive_log_uri="file:///data/backup/archive",
)
...
obshell-sdk-goによる対応APIメソッドのリクエスト方法については、テナントの復旧を開始するを参照してください。
...
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
request := client.V1().NewRestoreRequest(
"tenant1",
"file:///data/backup/data",
[]v1.ZoneParam{{
Name: "zone1",
UnitConfigName: "unit1",
UnitNum: 1,
}})
request.SetArchiveLogUri("file:///data/backup/archive")
dag, err := client.V1().RestoreWithRequest(request)
...
ステップ2:テナントレベルの復旧タスクを確認する
任意のobshellの/api/v1/tenant/:name/restore/overviewインターフェースを呼び出すことで、テナントレベルの復旧タスクを確認できます。
コマンドラインで対応するAPIインターフェースを呼び出す方法については、テナントの復旧状況を確認するを参照してください。
[admin@test001 ~]$ curl
-H "Content-Type: application/json"
-X GET
http://10.10.10.1:2886/api/v1/tenant/tenant1/restore/overview
obshell-sdk-pythonを使用して対応するAPIメソッドをリクエストする方法については、テナントの復元状況の確認を参照してください。
...
client = ClientSet("10.10.10.1", 2886, PasswordAuth("****"))
client.v1.get_tenant_restore_overview("tenant1")
...
obshell-sdk-goを使用して対応するAPIメソッドをリクエストする方法については、テナントの復元状況を確認するを参照してください。
...
client, err := services.NewClientWithPassword("10.10.10.1", 2886, "****")
res, err := client.V1().GetTenantRestoreOverview("tenant1")
...
obshellコマンドによる復元
ステップ1:テナントの復元を実行する
任意のノードでobshell tenant restoreコマンドを実行すると、テナントの復元がトリガーされます。詳細については、obshell テナントコマンドグループのobshell tenant restoreセクションを参照してください。
[admin@test001 ~]$ /home/admin/oceanbase/bin/obshell tenant restore tenant1 -d 'file:///data/backup/data' -u unit1 -z zone1 -a 'file:///data/backup/archive'
ステップ2:テナントの復元情報を照会する
使用したコマンドの詳細については、obshell restore コマンドグループのobshell restore showセクションを参照してください。
[admin@test001 ~]$ /home/admin/oceanbase/bin/obshell restore show tenant1