

翻訳は機械翻訳により提供されています。提供された翻訳内容と英語版の間で齟齬、不一致または矛盾がある場合、英語版が優先します。

# Amazon EBS ボリュームまたは EC2 インスタンスのリストア
<a name="restore"></a>

EC2 インスタンスにアタッチされたボリュームを 1 つだけ復元する必要がある場合は、そのボリュームを個別に復元し、既存のボリュームをデタッチして、復元したボリュームを EC2 インスタンスにアタッチできます。すべての関連ボリュームを含む EC2 インスタンス全体をリストアする必要がある場合は、インスタンスの Amazon マシンイメージ (AMI) バックアップを使用する必要があります。

復旧時間を短縮し、依存するアプリケーションやプロセスへの影響を減らすには、復元プロセスで置き換えるリソースを考慮する必要があります。最良の結果を得るためには、リストアプロセスが目標復旧時点 (RPO) と目標復旧時間 (RTO) を満たしていること、およびリストアプロセスが期待通りに動作することを検証するために、より低い環境 (たとえば非本番環境) でリストアプロセスを定期的にテストしてください。リストアプロセスが、リストアするインスタンスに依存するアプリケーションやサービスにどのような影響を与えるかを検討し、必要に応じてリストアを調整します。リストアプロセスをできるだけ自動化し、テストすることで、リストアプロセスが失敗したり、実施に一貫性がなくなったりするリスクを減らします。

複数のインスタンスでトラフィックを処理する Elastic Load Balancing を使用している場合、障害が発生したインスタンスや障害のあるインスタンスをサービスから外すことができます。その後、新しいインスタンスを復元して置き換えることができます。その間、他のインスタンスはユーザーに影響を与えずにトラフィックを処理し続けます。

以下に説明するリストアプロセスは、Elastic Load Balancing を使用していないインスタンスの場合です:
+ EBS スナップショットからの個々のファイルとディレクトリの復元
+ Amazon EBS スナップショットからの EBS ボリュームの復元
+ EBS スナップショットからの EC2 インスタンスの作成または復元
+ AMI からの実行中のインスタンスの復元

## EBS スナップショットからファイルとディレクトリの復元
<a name="restore-files"></a>

[EBS スナップショット](https://docs.aws.amazon.com/ebs/latest/userguide/ebs-snapshots.html)は、スナップショットの作成に使用された元のボリュームの正確なレプリカを提供します。個々のファイルまたはディレクトリを復元するには、以下の手順を実行する必要があります。

1. [まず、ファイルまたはディレクトリを含む EBS スナップショット](https://docs.aws.amazon.com/prescriptive-guidance/latest/backup-recovery/restore.html#restore-snapshot)からボリュームを復元します。

1. ファイルを復元する EC2 インスタンスにボリュームをアタッチします。

1. 復元されたボリュームから EC2 インスタンスボリュームにファイルをコピーします。

1. 復元したボリュームをデタッチして削除します。

## Amazon EBS スナップショットからの EBS ボリュームの復元
<a name="restore-snapshot"></a>



スナップショットからボリュームを作成し、インスタンスにアタッチすることで、既存の EC2 インスタンスにアタッチされたボリュームをリストアできます。コンソール、 AWS CLI、または API 操作を使用して、既存のスナップショットからボリュームを作成できます。その後、オペレーティングシステムを使用してボリュームをインスタンスにマウントできます。

Amazon EBS スナップショットからのデータは、非同期で EBS ボリュームにロードされることに注意します。データがロードされていないボリュームにアプリケーションがアクセスすると、Amazon S3 からデータがロードされている間、通常よりもレイテンシーが高くなります。レイテンシーの影響を受けやすいアプリケーションにおいてこの影響を回避するには、次の 2 つのオプションがあります。
+ [EBS ボリュームの初期化](https://docs.aws.amazon.com/ebs/latest/userguide/ebs-initialize.html)が可能です。
+ 追加料金で、Amazon EBS は[高速スナップショットリストア](https://docs.aws.amazon.com/ebs/latest/userguide/ebs-fast-snapshot-restore.html)をサポートし、ボリュームの初期化を不要にします。

同じマウントポイントを使用する必要のあるボリュームを交換する場合は、そのボリュームをアンマウントして、新しいボリュームをその場所にマウントできるようにします。ボリュームをアンマウントするには、まずそのボリュームを使用しているプロセスをすべて停止します。ルートボリュームを置き換える場合は、ルートボリュームをデタッチする前にインスタンスを停止する必要があります。

たとえば、コンソールを使用してボリュームを以前の時点のバックアップに復元するには、次の手順に従います。

1. Amazon EC2 コンソールの **[Elastic Block Store]** メニューで、**[Snapshots]** を選択します。

1. 復元したいスナップショットを検索し、選択します。

1. **[アクション]**、そして**[ボリュームの作成] **の順に選択します。

1. EC2 インスタンスと同じアベイラビリティゾーンに新しいボリュームを作成します。

1. Amazon EC2 のコンソールで、インスタンスを選択します。

1. インスタンスの詳細で、**[Root device]** エントリーまたは **[Block Devices]** エントリーで置き換えたいデバイス名をメモします。

1. ボリュームをデタッチします。ルートボリュームと非ルートボリュームでは手順が異なります。

   ルートボリュームの場合:

   1. EC2 インスタンスを停止します。

   1. **[EC2 Elastic Block Store Volumes]** メニューで、置き換えるルートボリュームを選択します。

   1. **[アクション] **を選択して、**[ボリュームのデタッチ] **を選択します。

   1. **[EC2 Elastic Block Store Volumes]** メニューで、新しいボリュームを選択します。

   1. **[アクション] **を選択し、**[ボリュームのアタッチ] **を選択します。

   1. ボリュームをアタッチするインスタンスを選択し、先にメモしたのと同じデバイス名を使用します。

   非ルートボリュームの場合:

   1. **[EC2 Elastic Block Store Volumes]** メニューで、置き換えたい非ルートボリュームを選択します。

   1. **[アクション] **を選択して、**[ボリュームのデタッチ] **を選択します。

   1. **[EC2 Elastic Block Store ボリューム]** メニューで新しいボリュームを択し、**[アクション]**、**[ボリュームのアタッチ]** の順に選択して新しいボリュームをアタッチします。アタッチするインスタンスを選択し、使用可能なデバイス名を選択します。

   1. インスタンスのオペレーティングシステムを使用して既存のボリュームをアンマウントし、新しいボリュームをその場所にマウントします。

      Linux では、`umount` コマンドを使うことができます。Windows では、ディスク管理システムユーティリティなどの論理ボリュームマネージャ (LVM) を使うことができます。

   1. **[EC2 Elastic Block Store ボリューム] **メニューでそのボリュームを選択し、**[アクション]**、**[ボリュームのデタッチ] **の順に選択して、置き換える前のボリュームをデタッチします。

をオペレーティングシステムコマンド AWS CLI と組み合わせて使用して、これらのステップを自動化することもできます。

## EBS スナップショットからの EC2 インスタンスの作成または復元
<a name="instance-from-snapshot"></a>

EC2 インスタンス全体をリストアするために使用するバックアップを作成するには、Amazon マシンイメージ (AMI) を作成することを推奨します。AMI は、仮想化タイプなどのマシン情報を取得します。また、EC2 インスタンスにアタッチされている各ボリュームのスナップショットを作成し、デバイスマッピングも含めて、同じ構成でリストアできるようにします。

**注記**  
ほとんどの場合、Windows、RedHat、SUSE、SQL Server の AMI には、正しいライセンス情報が存在する必要があります。詳細については、「[AMI 請求情報の理解](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/ami-billing-info.html)」を参照してください。スナップショットから AMI を作成する場合、`RegisterImage` オペレーションはスナップショットのメタデータから正しい請求情報を取得しますが、これには適切なメタデータが必要です。正しい請求情報が適用されたかどうかを確認するには、新しい AMI の **[プラットフォームの詳細]** フィールドを確認します。フィールドが空であるか、所定のオペレーティングシステムコード (Windows、RedHat、SUSE、SQL など) と一致しない場合、AMI の作成は失敗しているため、この AMI を破棄して「[インスタンスから AMI を作成する](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/creating-an-ami-ebs.html#how-to-create-ebs-ami)」の手順に従う必要があります。

EBS スナップショットを使用してインスタンスを復元する必要がある場合は、まず、新しい EC2 インスタンスのルートボリュームとなる EBS スナップショットから AMI を作成します。

1. Amazon EC2 コンソールの **[Elastic Block Store]** メニューで、**[スナップショット]** を選択します。

1. 新しい EC2 インスタンスのルートボリュームの作成に使用するスナップショットを検索して選択します。

1. **[アクション] **を選択し、**[スナップショットから画像を作成]** を選択します。

1. 画像の名前 (例えば `YYYYMMDD-restore-for-i-012345678998765de`) を入力し、新しい画像に適したオプションを選択します。

1. (Windows、RedHat、SUSE、SQL Server のみ) 正しい請求情報が適用されたかどうかを確認するには、新しい AMI の **[プラットフォームの詳細]** フィールドを確認します。フィールドが空であるか、所定のオペレーティングシステムコード (**Windows** や **RedHat** など) と一致しない場合、AMI の作成は失敗しているため、この AMI を破棄して[インスタンスから AMI を作成する](https://docs.aws.amazon.com/AWSEC2/latest/UserGuide/creating-an-ami-ebs.html#how-to-create-ebs-ami)の手順に従う必要があります。

イメージが作成されて使用できるようになったら、ルートボリュームの EBS スナップショットを使用する新しい EC2 インスタンスを起動できます。

## AMI からの実行中のインスタンスの復元
<a name="restore-ami"></a>

AMI バックアップから新しいインスタンスを起動して、実行中の既存のインスタンスを置き換えることができます。ひとつの方法は、既存のインスタンスを停止し、オフラインのまま AMI から新しいインスタンスを起動し、必要なアップデートを実行することです。このアプローチにより、両方のインスタンスが同時に実行されて競合が発生するリスクが軽減されます。インスタンスが提供するサービスがダウンしている場合や、メンテナンスの時間帯に復元を実行している場合には、この方法でも問題ありません。新しいインスタンスをテストしたら、古いインスタンスに割り当てられた Elastic IP アドレスを再割り当てできます。その後、新しいインスタンスを指すようにドメインネームサービス (DNS) レコードを更新できます。

ただし、復元中に稼働中のインスタンスのダウンタイムを最小限に抑える必要がある場合は、AMI バックアップから新しいインスタンスを起動してテストすることを検討します。その上で、既存のインスタンスを新しいインスタンスで置き換えます。

両方のインスタンスが実行されている間は、新しいインスタンスがプラットフォームレベルまたはアプリケーションレベルの衝突を引き起こさないようにする必要があります。たとえば、同じ SID とコンピューター名で実行されているドメインに参加している Windows インスタンスで問題が発生する可能性があります。一意の識別子を必要とするネットワークアプリケーションやサービスでも同様の問題が発生する可能性があります。

準備が整う前に他のサーバーやサービスが新しいインスタンスに接続するのを防ぐには、セキュリティグループを使用して、アクセスやテスト用に自分の IP アドレスを除く新しいインスタンスのすべてのインバウンド接続を一時的にブロックします。また、新しいインスタンスのアウトバウンド接続を一時的にブロックして、サービスやアプリケーションが他のリソースへの接続や更新を開始しないようにすることもできます。新しいインスタンスの準備ができたら、既存のインスタンスを停止し、新しいインスタンスでサービスとプロセスを開始し、実装したインバウンドまたはアウトバウンドのネットワーク接続のブロックを解除します。