Oracle のバックアップと DR サービス

Oracle データベースは、ミッション クリティカルなアプリケーションをサポートする一般的なエンタープライズ クラスのデータベースです。このページでは、Oracle データベース環境のバックアップと DR サービスについて説明します。関連するアーキテクチャは、アプリケーションで整合性のある永久増分方式で Google Cloudにバックアップします。また、マルチテラバイトの Oracle データベースを直ちに復旧し、クローンを作成できます。

仕組み

以降のセクションでは、データの取得とデータ復元のプロセスについて説明します。

データ キャプチャ

  1. Backup and DR エージェントが Oracle サーバーにデプロイされている。

  2. データベース サーバーにステージング ディスクをマウントします。

  3. RMAN 増分 API を呼び出して、変更されたブロックをコピーします。

  4. RMAN 増分マージを呼び出して、新しい仮想フルを作成します。

  5. データベース サーバーからステージング ディスクのマウントを解除します。

  6. バックアップと DR が内部スナップショットを取得します。特定時点の合成フルが準備完了です。

データ復旧

バックアップと DR は、ISCSI または NFS 経由で書き換え可能なステージング ディスクを即座にマウントし、データベースをオンラインにします。

Oracle バックアップ API

バックアップと DR では、次の Oracle API が使用されます。

  • RMAN イメージコピー: データファイルの物理構造がすでに存在しているため、データファイルのイメージコピーを高速に復元できます。RMAN ディレクティブ BACKUP AS COPY により、データベース全体のすべてのデータファイルのイメージコピーが作成され、データファイル形式が保持されます。

  • ASM と CRS API: ASM バックアップ ディスク グループは、ASM と CRS API を使用して管理されます。

  • RMAN アーカイブログ バックアップ API: 生成されたアーカイブログはステージング ディスクにバックアップされ、本番環境のアーカイブの場所からパージされます。

バックアップと DR サービスを他のバックアップ プロダクトと併用する場合の競合を最小限に抑える

バックアップと DR サービスは、本番環境データベースからデータをキャプチャする従来のプロダクトと共存できます。以下のベスト プラクティスは、エクスペリエンスの向上に役立ちます。

Oracle データベースのバックアップ スケジュール

ベスト プラクティス 以前のバックアップ ソフトウェアが完了する時間に開始するように、バックアップと DR サービスのデータベース バックアップ ジョブをスケジュールします。バックアップと DR サービスのデータベース バックアップ ジョブが正常に完了した直後に、以前のバックアップ ソフトウェアを実行するようにスケジュールしないでください。
理由 従来のバックアップ ジョブとバックアップと DR サービスのデータベース バックアップ ジョブが同時に実行されると、データベース サーバーのパフォーマンスに重大な影響を与え、不安定になり、停止する可能性があります。また、Oracle の場合、1 つまたは両方のソリューションのバックアップ イメージが無効になる可能性があります。

Oracle アーカイブログの管理

Oracle は、データベースのバックアップ中に生成されたアーカイブ ログを使用して、そのバックアップの整合性と復元可能性を確保します。そのため、データベース バックアップ ジョブ中にアーカイブ ログがパージされた場合、そのバックアップ コピーは復元できません。

要件 ログを管理(キャプチャ、切り捨て、パージ)できるのは、以前のバックアップ ソフトウェアまたは Backup and DR サービスのいずれか、1 つのシステムのみです。
ベスト プラクティス バックアップと DR ジョブ中に Oracle アーカイブログをパージしないようにします。また、バックアップと DR サービスがレガシー バックアップ RMAN ジョブ中にアーカイブログをパージしないようにします。
レガシー ソフトウェアがアーカイブログを管理している場合は、バックアップと DR バックアップ ジョブの開始時にレガシー バックアップ ソフトウェアでアーカイブログのパージ ジョブを無効にし、終了時にパージ ジョブを再開するか、アーカイブログを 24 時間以上保持してからパージします。
理由 データベース バックアップ ジョブ中にアーカイブ ログがパージされると、そのデータベース バックアップ イメージは復元できない可能性があります。

RMAN メタデータがレガシー バックアップと競合し、バックアップと DR サービスのバックアップが古くなる

デフォルトでは、Backup and DR Service アプリケーションの詳細と設定のパラメータ DO NOT UNCATALOG は [いいえ] に設定されています。Backup and DR データファイルのバックアップは、バックアップの開始時にカタログに登録され、ジョブの終了時にカタログ登録解除されます。これを [Yes] に設定すると、各バックアップ ジョブの後に RMAN データファイルのバックアップがカタログに登録されるため、データファイルの数が多いデータベースのバックアップ時間が最適化されます。ただし、他のバックアップ プロダクトと干渉します。

要件 [Backup and DR application details & settings] パラメータ Do not uncatalog を [No] に設定します。
ベスト プラクティス Backup and DR サービスのデータベース バックアップは永続増分方式です。これは、RMAN 増分マージ API で RMAN イメージ コピーを使用することによって実現されます。最初の RMAN バックアップは、バックアップ ディスクの内部スナップショットを含む、Backup and DR バックアップ ディスク上のデータベース データファイルの完全なイメージコピーです。その後の RMAN 増分バックアップは、バックアップと DR バックアップ ディスクで RMAN 増分マージとともに実行され、スナップショット前の増分変更で最後の完全バックアップが更新されます。ただし、サードパーティ データベース バックアップまたはバックアップのクロスチェックがバックアップと DR データベース バックアップの後に実行された場合、バックアップと DR バックアップのすべてのバックアップ データファイルは、RMAN メタデータで無効とマークされます。バックアップと DR アプリケーションの詳細と設定パラメータ Do not uncatalog が [はい] に設定されていると、次のエラーが発生します。ステージング デバイスからイメージ コピーのカタログを作成できませんでした。バックアップは失敗します。他のレガシー バックアップ プロダクトと共存するには、Do not uncatalog を [No] のままにします。
理由 デフォルトでは、パラメータ Do not uncatalog> in Backup and DR application details & settings is set to No. Setting this to Yes interferes with other backup products.

Oracle データベースのブロック変更のトラッキング(BCT)

Oracle ブロック変更のトラッキングでは、変更されたブロックを特定することで、高速なデータベース バックアップを実現できます。バックアップ オペレーションには、変更されたブロックのみが含まれます。

  • バックアップと DR サービスの永久増分方式は、BCT が有効または無効で実行されているデータベースをサポートしています。BCT が有効になっていない場合、増分バックアップ時間は長くなります。

  • 変更ブロック トラッキングがデータベース レベルで有効になっている。

  • Oracle は、各データファイル内の変更されたブロックを、データベース領域に保存される小さなバイナリ ファイルであるトラッキング ファイルに記録します。

  • BCT が有効になっている場合、RMAN は BCT ファイルを使用して、増分バックアップの変更ブロックを取得します。

  • データベースの変更ブロック トラッキングが有効になっていない場合、RMAN は増分バックアップ中にデータベース内のすべてのデータファイルのデータファイル内の各ブロックをスキャンします。

バックアップと DR の整合性グループ内の Oracle データベースを保護する

ほとんどの構成では、整合性グループに 1 つの Oracle データベース アプリケーションと、Oracle サーバーからの任意の数のファイル システム アプリケーションを含めることができます。テスト / 開発やその他のビジネス アジリティのユースケースでは、Oracle データベースに整合性グループを使用することをおすすめします。

TDE を使用する Oracle データベース

バックアップと DR サービスは、さまざまな構成で Oracle データベースのさまざまなキャプチャ方法と表示方法をサポートしています。これには、透過的データ暗号化(TDE)が構成された Oracle データベースのバックアップ、復元、アプリケーション対応マウント オペレーションが含まれます。

TDE を使用する Oracle データベースの場合、ソース バックアップ ホストのウォレット ファイルが、Application Aware マウントのターゲット ホストで使用可能である必要があります。これにはいくつかの方法があります。

  • ウォレット ファイルは、バックアップ ソース サーバーから移行先のマウント サーバーにコピーし、Oracle がアクセスするように構成できます。
  • Oracle ウォレット ファイルがネットワーク上の中央の共有デバイスに保存されている場合は、Appaware マウント ターゲット Oracle インスタンスがファイルにアクセスするように構成する必要があります。
  • Oracle 構成ファイルの場所の詳細設定を設定することで、Backup and DR Service のバックアップ中に Oracle ウォレット ファイルがキャプチャされた場合は、次の手順でウォレット ファイルを取得できます。

    1. データベースをターゲット ホストに標準マウントします。
    2. ウォレット ファイルを標準データベース マウントからターゲット ホストにコピーし、それらを使用するように Oracle を構成します。
    3. ターゲット ホストからデータベースをマウント解除します。
    4. ターゲット ホストへのデータベースのApplication Aware マウントを実行します。

Oracle Exadata Database または Oracle ExaCC を使用したバックアップと DR

バックアップ/リカバリ アプライアンスは、iSCSI または Oracle dNFS プロトコルを介した Exadata データのキャプチャと表示をサポートしています。

  • バックアップ/リカバリ アプライアンスは、ネットワーク(データパス内ではない)の iSCSI または Oracle dNFS 経由で接続されています。

  • RMAN バックアップは、RMAN を使用して、バックアップと DR によってファイル システムまたは ASM ディスク グループとして提示されたコピー データストアに直接書き込みます。

  • データ キャプチャ形式: [ASM ディスク グループ](iSCSI のみ)または [ファイル システム](dNFS または iSCSI)の下。

  • バックアップと DR の永久増分バックアップは、RMAN 増分更新バックアップを使用して、イメージコピー バックアップをロールフォワードします。

Exadata データと ExaCC のバックアップと DR キャプチャ

バックアップ/リカバリ アプライアンスとの通信を容易にし、データベースのバックアップ用に RMAN API を呼び出すには、Backup and DR エージェントを Exadata サーバーにインストールする必要があります。

バックアップと DR エージェントは、バックアップと DR ディスクを iSCSI ターゲットとして公開し、Exadata サーバーにマッピングします。データ キャプチャ形式は、ASM ディスク グループまたはファイル システムのいずれかです。

バックアップ/リカバリ アプライアンスとの通信を容易にし、データベースのバックアップ用に RMAN API を呼び出すために、各 Exadata ホストのユーザー空間に Backup & DR エージェントをインストールします。

ASM ディスク グループの形式をキャプチャする

バックアップ中、バックアップと DR エージェントは次の処理を行います。

  1. 論理ディスクを iSCSI ターゲットとして Exadata サーバーにマッピングして公開します。

  2. バックアップと DR ディスクのパスを ASM ディスク文字列に追加します。

  3. ASM ディスク文字列がパラメータ ファイルに追加され、CRS プロファイルに存在しないことを確認します。

  4. バックアップ ディスクと DR ディスクを使用して、外部冗長性として ASM ディスク グループを作成します。

    • RMAN バックアップ。RMAN を使用して、バックアップ/リカバリ アプライアンスによって ASM ディスク グループまたはファイル システムとして提示されたコピー データストアに直接書き込みます。

    • RMAN 増分更新バックアップを使用して、イメージ コピー バックアップをロールフォワードする永久増分バックアップ。

dNFS を使用してファイル システム内の形式をキャプチャする

Oracle Direct NFS(dNFS)は、NAS ストレージ デバイス(TCP/IP 経由でアクセス可能)にある NFS ストレージへのアクセスを高速かつスケーラブルに提供する、最適化された NFS(ネットワーク ファイル システム)クライアントです。Direct NFS は、ASM と同様にデータベース カーネルに直接組み込まれています。

dNFS プロトコルは、NFS 共有としてファイル システム ベースのバックアップに使用できます。

バックアップと DR エージェントは、バックアップと DR ディスクを公開し、NFS 共有として Exadata サーバーにマッピングします。

Exadata サーバーで dNFS を使用する前提条件:

  • Exadata サーバーで dNFS を有効にします。

    cd $ORACLE_HOME/rdbms/lib make -f ins_rdbms.mk nfs on

  • データベースを再起動します。

    RMAN API を使用して、バックアップ/リカバリ アプライアンスによって提供される dNFS 共有のファイル システムにデータベースをバックアップします。

ターゲット DB サーバーの再起動後に、バックアップと DR で保護された ASM ディスク グループをオンラインに戻す

バックアップと DR のコピーがマウントされているデータベース サーバーが再起動された場合、または再起動時またはクラッシュ時にデータベースのバックアップと DR バックアップが進行中の場合は、次の手順でバックアップと DR ディスク グループのマウントを復元します。

  1. ターゲット データベース サーバーが復元され、ASM システムと RAC システムも稼働していることを確認します。

  2. バックアップと DR エージェントを再起動します(root から)。

  3. ASM 環境を設定する。

  4. ASM sqlplus にログインして、ディスク グループのステータスを確認します。

    select name, state from v$asm_diskgroup where name = '<dg name>';)
    
  5. マウントされていない場合は、ディスク グループ alter diskgroup <dg name> mount; をマウントします。

  6. Oracle OS にログインしてデータベース環境を設定し、データベースを起動します。

次のステップ

Oracle データベースのバックアップの前提条件を確認する。

Oracle のバックアップと DR に関するその他のドキュメント