このページでは、 Google Cloud コンソールを使用して、Compute Engine インスタンスをバックアップ ボールトにバックアップする方法について説明します。バックアップを Backup Vault に送信すると、不変性と強制保持が実現されます。Backup Vault を使用すると、バックアップを単一のリージョンに保存できます。次のいずれかのバックアップ要件がある場合は、管理コンソールを使用して Compute Engine インスタンスをバックアップできます。
- マルチリージョンまたはリージョン間のバックアップ
- VM にアタッチされている特定のディスクのバックアップ
- タグに基づく Google Compute Engine VM の自動保護
- Google Cloud コンソールベースのバックアップ プランとバックアップ ボールトが、VM が実行されているリージョンでサポートされていない場合
Google Cloud コンソールで、バックアップ プランを適用して Compute Engine インスタンスをバックアップ ボールトにバックアップできます。バックアップは次の 2 つの方法で行うことができます。どちらの方法でも、バックアップを Backup Vault に安全に保存できるため、データ損失やその他の予期しないイベントが発生した場合に Compute Engine インスタンスを確実に復元できます。
- スケジュール バックアップ。Compute Engine インスタンスは、日次、週次、月次、年次など、特定の間隔で自動的にバックアップできます。
- オンデマンド バックアップ。オンデマンド バックアップは、必要に応じていつでも作成できます。オンデマンド バックアップは、インスタンスに大幅な変更を加える前にバックアップを作成するときや、アドホックなデータ保護に役立ちます。
始める前に
- Compute Engine インスタンスがある場所で Backup and DR Service API を有効にします。
- API の有効化
- Backup Vault を作成する
- バックアップ プランを作成する
- バックアップ ユーザーに IAM ロールと権限を割り当てる
- Compute Engine プロジェクトで Backup Vault へのアクセス権を付与する
- バックアップと DR バックアップ ジョブをモニタリングするように、バケットにログ分析を設定します。
制限事項
インスタンスで次のいずれかの構成を使用している場合、Backup and DR サービスは Compute Engine インスタンスのバックアップ ボールトへのバックアップをサポートしていません。
- エクストリーム永続ディスクがアタッチされた VM インスタンス。
- Hyperdisk Extreme ディスクがアタッチされている VM インスタンス。
- C3D、H3、A3、Z3 マシンタイプを使用する VM インスタンス。
- 顧客管理の暗号鍵(CMEK)または顧客指定の暗号鍵(CSEK)を使用する VM インスタンス。
- アタッチされたディスクのない VM インスタンス。
- 200 テラバイト(TB)を超える VM インスタンス。
バックアップ ユーザーの IAM ロールと権限
スケジュール設定されたバックアップの構成やオンデマンド バックアップの実行に必要な権限を取得するには、バックアップ ボールト プロジェクトに対する次の IAM ロールを付与するよう管理者に依頼してください。
-
バックアップと DR バックアップ ユーザー (
roles/backupdr.backupUser
) -
閲覧者 (
roles/viewer
)
ロールの付与については、プロジェクト、フォルダ、組織へのアクセス権の管理をご覧ください。
これらの事前定義ロールには、スケジュール設定されたバックアップの構成やオンデマンド バックアップの実行に必要な権限が含まれています。必要とされる正確な権限については、「必要な権限」セクションを開いてご確認ください。
必要な権限
スケジュール設定されたバックアップを構成するか、オンデマンド バックアップを実行するには、次の権限が必要です。
-
backupdr.backupPlans.list
-
backupdr.backupPlanAssociations.createForComputeInstance
-
backupdr.backupPlanAssociations.list
-
backupdr.backupPlanAssociations.get
-
backupdr.backupPlanAssociations.triggerBackupForComputeInstance
-
backupdr.backupPlanAssociations.deleteForComputeInstance
-
backupdr.backupPlans.useForComputeInstance
-
backupdr.locations.list
-
backupdr.operations.get
-
cloudasset.assets.searchAllResources
カスタムロールや他の事前定義ロールを使用して、これらの権限を取得することもできます。
Compute Engine プロジェクトでバックアップ ボールトへのアクセス権を付与する
Backup Vault が作成されているプロジェクトとは異なるプロジェクトの Compute Engine VM インスタンスをバックアップするには、Compute Engine プロジェクト内の Backup Vault サービス エージェントに Backup and DR Compute Engine Operator(roles/backupdr.computeEngineOperator
)IAM ロールを付与する必要があります。
バックアップ ボールトが作成されたプロジェクト内の Compute Engine VM インスタンスをバックアップするには、ロールを付与する必要はありません。
バックアップするプロジェクト内のバックアップ ボールト サービス エージェントにロールを付与する方法については、サービス エージェントにロールを付与するをご覧ください。
スケジュール バックアップを構成する
次の手順で、Compute Engine インスタンスのスケジュール設定されたバックアップを構成します。
コンソール
Google Cloud コンソールで、[Vaulted backups] ページに移動します。
[バックアップのスケジュールを設定] をクリックします。
[プロジェクト] リストで [参照] をクリックし、Compute Engine インスタンスが存在するプロジェクトを選択します。
[リージョン] リストから、インスタンスが配置されているリージョンを選択します。
[リソース] リストで [参照] をクリックします。
バックアップする Compute Engine インスタンスを選択し、[完了] をクリックします。
[続行] をクリックします。
[バックアップ プラン] リストで [選択] をクリックします。
Compute Engine インスタンスを保護するバックアップ プランを選択します。
[完了] をクリックします。
バックアップの詳細を確認し、[スケジュール] をクリックします。
gcloud
インスタンス ID を取得します。
gcloud compute instances describe VM_NAME --zone=VM_ZONE --format="value(id)"
次のように置き換えます。
VM_NAME
: VM インスタンスの名前。VM_ZONE
: VM が配置されているロケーション。
スケジュール設定されたバックアップを構成する。
gcloud backup-dr backup-plan-associations create BACKUP_PLAN_ASSOCIATION_NAME \ --location=VM_REGION \ --resource=projects/VM_PROJECT_ID/zones/VM_ZONE/instances/VM_ID \ --backup-plan=projects/PROJECT_ID/locations/LOCATION/backupPlans/BACKUP_PLAN
次のように置き換えます。
BACKUP_PLAN_ASSOCIATION_NAME
: バックアップ プランの関連付けの名前。VM_REGION
: Compute Engine インスタンスが配置されているリージョン。VM_PROJECT_ID
: Compute Engine インスタンスが配置されているプロジェクトの名前。VM_ZONE
: Compute Engine インスタンスが配置されているゾーン。VM_ID
: Compute Engine インスタンス ID。PROJECT_ID
: バックアップ プランが存在するプロジェクトの名前。LOCATION
: バックアップ プランが存在するリージョン。BACKUP_PLAN
: Compute Engine インスタンスを関連付けるバックアップ プランの名前。
Terraform
スケジュールされたバックアップを一覧表示する
次の手順で、バックアップされた Compute Engine インスタンスを一覧表示します。
コンソール
Google Cloud コンソールで、[Vaulted backups] ページに移動します。
[Vaulted backups] ページには、バックアップ プランが適用され、バックアップがプロジェクト内の Backup Vault に保存されているインスタンスのみが表示されます。
gcloud
スケジュールされたバックアップを一覧表示します。
gcloud backup-dr backup-plan-associations list \ --location=LOCATION \ --project=PROJECT_ID
次のように置き換えます。
PROJECT_ID
: プロジェクトの名前。LOCATION
: スケジュール設定されたバックアップのロケーション。
オンデマンド バックアップの作成
バックアップ計画を使用して Compute Engine インスタンスのオンデマンド バックアップを開始するには、任意のバックアップ ルールをトリガーしてすぐに実行します。オンデマンド バックアップは増分バックアップであり、前回のバックアップ以降に変更されたデータのみをキャプチャします。
オンデマンド バックアップを作成するときに、Compute Engine インスタンスに関連付けられたバックアップ プランからルールを選択できます。このルールは、オンデマンド バックアップの削除タイミングを決定します。バックアップ ジョブのステータスは、[ジョブ] ページで確認できます。詳細については、 Google Cloud コンソールでバックアップと復元ジョブをモニタリングするをご覧ください。
オンデマンド バックアップを作成するには、次の手順を行います。
コンソール
- [VM インスタンス] > [詳細] > [バックアップ プラン] に移動して、オンデマンド バックアップを作成します。
- [Create On-Demand Backup] をクリックします。オンデマンド バックアップを作成するための適切な権限があることを確認します。
- バックアップ ルールを選択します。
- [作成] をクリックして、オンデマンド バックアップの作成プロセスを開始します。
- オンデマンド バックアップ ジョブのステータスを表示するには、[通知] をクリックします。
gcloud
オンデマンド バックアップを作成します。
gcloud backup-dr backup-plan-associations trigger-backup BACKUP_PLAN_ASSOCIATION_NAME \ --project=PROJECT_ID --location=LOCATION \ --backup-rule-id=RULE_ID
次のように置き換えます。
BACKUP_PLAN_ASSOCIATION_NAME
: バックアップ プランの関連付けの名前。gcloud backup-dr backup-plan-associations list --location=LOCATION --project=PROJECT_ID
コマンドを実行して、Compute Engine インスタンスに関連付けられているバックアップ プランのリストを取得します。PROJECT_ID
: プロジェクトの名前。LOCATION
: スケジュール設定されたバックアップのロケーション。RULE_ID
: オンデマンド バックアップの実行に関連付けるバックアップ ルールの名前。
Compute Engine インスタンスの保護を解除する
Compute Engine インスタンスの保護を解除するには、インスタンスに適用されているバックアップ プランを削除します。Compute Engine インスタンスからバックアップ プランを削除しても、バックアップ プランや、インスタンスの使用中に作成されたバックアップは削除されません。これらの既存のバックアップには引き続きアクセスして管理できます。
次の手順で、Compute Engine インスタンスの保護を解除します。
コンソール
Google Cloud コンソールで、[Vaulted backups] ページに移動します。
バックアップ プランを削除するインスタンスの名前をクリックします。
[バックアップ プランを削除] を選択します。
gcloud
Compute Engine インスタンスの保護を解除する。
gcloud backup-dr backup-plan-associations delete BACKUP_PLAN_ASSOCIATION_NAME\ --project=PROJECT_ID \ --location=LOCATION
次のように置き換えます。
BACKUP_PLAN_ASSOCIATION_NAME
: 削除するバックアップの名前。PROJECT_ID
: プロジェクトの名前。LOCATION
: スケジュール設定されたバックアップのロケーション。