Oracle から Cloud SQL for PostgreSQL へのデータフローの概要

ソースから宛先インスタンスへのデータの流れを理解するには、移行タイプと移行フェーズという 2 つの重要なコンセプトを理解する必要があります。Database Migration Service は、継続的移行と 1 回限りの移行の 2 種類の移行をサポートしています。異種 Oracle から Cloud SQL for PostgreSQL への移行では、継続的移行のみを使用できます。

継続的移行では、データは完全ダンプと変更データ キャプチャ(CDC)の 2 つのフェーズで移行されます。

完全なダンプ フェーズ

完全なダンプフェーズは、移行プロセスの最初の部分です。完全ダンプ中、Database Migration Service は移行元インスタンスに接続し、移行用に選択したデータベースのコンテンツを読み取って、Cloud SQL for PostgreSQL の移行先インスタンスにデータを読み込みます。このフェーズでは、Database Migration Service がデータベースの実際のコンテンツをキャプチャします。

完全ダンプ フェーズでは、Database Migration Service はパフォーマンスを向上させるために、移行元データベースへの複数の接続を開くことができます。同時接続の数は、 移行ジョブの作成時に構成できます。

データ移動をきめ細かく制御するには、Database Migration Service の外部で、完全なダンプを実行して、移行先のインスタンスにデータを読み込むこともできます。このフェーズを手動で実行することを選択した場合、移行ジョブは CDC フェーズから開始され、Database Migration Service は、redo ログファイルのシステム変更番号(SCN)を開始点として指定することを想定します。

変更データ キャプチャ(CDC)

フルダンプ フェーズが終了すると(または、フルダンプを自分で実行して CDC フェーズから開始する場合)、Database Migration Service は CDC フェーズに切り替わり、移行元データベースの変更を継続的にモニタリングし、移行先インスタンスに継続的に複製します。このフェーズでは、Database Migration Service は移行元データベースから実際のデータをコピーしません。代わりに、ログファイルを読み取って宛先の変更を複製します。

Database Migration Service は、Oracle LogMiner API を使用して、移行元データベース内のアーカイブされた Oracle REDO ログファイルにアクセスして解析します。Database Migration Service を使用して Oracle データベースを Cloud SQL for PostgreSQL に移行する前に、最適なパフォーマンスとデータ忠実度を実現するように Oracle の REDO ログファイルの設定を調整することをおすすめします。詳細については、 Oracle の REDO ログファイルを使用するをご覧ください。