AWS DMS を使用して Amazon RDS for Oracle からTiDB Cloudに移行する
このドキュメントでは、AWS Database Migration Service (AWS DMS) を使用して Amazon RDS for Oracle からTiDB Cloudサーバーレスにデータを移行する方法の例を段階的に説明します。
TiDB Cloudと AWS DMS について詳しく知りたい場合は、以下を参照してください。
AWS DMS を使用する理由
AWS DMS は、リレーショナル データベース、データ ウェアハウス、NoSQL データベース、その他の種類のデータ ストアの移行を可能にするクラウド サービスです。
PostgreSQL、Oracle、SQL Server などの異種データベースからTiDB Cloudにデータを移行する場合は、AWS DMS を使用することをお勧めします。
デプロイメントアーキテクチャ
大まかに言うと、次の手順に従います。
- ソース Amazon RDS for Oracle をセットアップします。
- ターゲットTiDB Cloudサーバーレスを設定します。
- AWS DMS を使用してデータ移行 (フルロード) を設定します。
次の図は、高レベルのアーキテクチャを示しています。
前提条件
始める前に、次の前提条件をお読みください。
次に、AWS DMS を使用して Amazon RDS for Oracle からTiDB Cloudにデータを移行する方法を学習します。
ステップ1. VPCを作成する
AWS コンソールにログインし、AWS VPC を作成します。後でこの VPC に Oracle RDS および DMS インスタンスを作成する必要があります。
VPC を作成する方法については、 VPC の作成参照してください。
ステップ2. Oracle DBインスタンスを作成する
作成した VPC に Oracle DB インスタンスを作成し、パスワードを覚えておき、パブリックアクセスを許可します。AWS スキーマ変換ツールを使用するには、パブリックアクセスを有効にする必要があります。本番環境でパブリックアクセスを許可することは推奨されないことに注意してください。
Oracle DB インスタンスを作成する方法については、 Oracle DBインスタンスを作成し、Oracle DBインスタンス上のデータベースに接続する参照してください。
ステップ3. Oracleでテーブルデータを準備する
次のスクリプトを使用して、github_events テーブルに 10000 行のデータを作成し、入力します。github イベント データセットを使用して、 GHアーカイブからダウンロードできます。これには 10000 行のデータが含まれています。次の SQL スクリプトを使用して、Oracle で実行します。
SQL スクリプトの実行が完了したら、Oracle のデータを確認します。次の例では、 DBeaver使用してデータを照会します。
ステップ4. TiDB Cloud Serverlessクラスターを作成する
TiDB Cloudコンソールにログインします。
クラスターページで、ターゲット クラスター名をクリックして概要ページに移動します。
右上隅の「接続」をクリックします。
「パスワードの生成」をクリックしてパスワードを生成し、生成されたパスワードをコピーします。
ステップ5. AWS DMSレプリケーションインスタンスを作成する
AWS DMS コンソールのレプリケーションインスタンスページに移動し、対応するリージョンに切り替えます。
VPC に
dms.t3.large
の AWS DMS レプリケーションインスタンスを作成します。
注記:
TiDB Cloud Serverless と連携する AWS DMS レプリケーションインスタンスを作成する詳細な手順については、 AWS DMS をTiDB Cloudクラスターに接続する参照してください。
ステップ6. DMSエンドポイントを作成する
AWS DMS コンソールで、左側のペインの
Endpoints
メニュー項目をクリックします。Oracle ソース エンドポイントと TiDB ターゲット エンドポイントを作成します。
次のスクリーンショットは、ソース エンドポイントの構成を示しています。
次のスクリーンショットは、ターゲット エンドポイントの構成を示しています。
注記:
TiDB Cloud Serverless DMS エンドポイントを作成する詳細な手順については、 AWS DMS をTiDB Cloudクラスターに接続する参照してください。
ステップ7. スキーマを移行する
この例では、スキーマ定義が単純なので、AWS DMS が自動的にスキーマを処理します。
AWS スキーマ変換ツールを使用してスキーマを移行する場合は、 AWS SCT のインストール参照してください。
詳細についてはAWS SCT を使用してソース スキーマをターゲット データベースに移行する参照してください。
ステップ8. データベース移行タスクを作成する
AWS DMS コンソールで、 データ移行タスクページに移動します。リージョンに切り替えます。次に、ウィンドウの右上隅にある[タスクの作成]をクリックします。
データベース移行タスクを作成し、選択ルールを指定します。
タスクを作成して開始し、タスクが完了するまで待機します。
テーブル統計をクリックしてテーブルを確認します。スキーマ名は
ADMIN
です。
ステップ9. 下流のTiDBクラスタのデータを確認する
TiDB Cloudサーバーレス クラスターに接続し、 admin.github_event
テーブルのデータを確認します。次のスクリーンショットに示すように、DMS はテーブルgithub_events
と 10000 行のデータを正常に移行しました。
まとめ
AWS DMS を使用すると、このドキュメントの例に従って、任意のアップストリーム AWS RDS データベースからデータを正常に移行できます。
移行中に問題や障害が発生した場合は、 クラウドウォッチのログ情報を確認して問題のトラブルシューティングを行うことができます。