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を呼び出す方法の説明については、テナントの復元を開始するを参照してください。この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