Data Transmission Service (DTS) を使用して、PolarDB for PostgreSQL (Oracle 互換) クラスターから AnalyticDB for MySQL 3.0 クラスターにデータを移行できます。
前提条件
ターゲットの AnalyticDB for MySQL V3.0 クラスターが作成されていること。詳細については、「クラスターの作成」をご参照ください。
ソースの PolarDB for PostgreSQL (Oracle 互換) クラスターで、wal_level パラメーターが logical に設定されていること。これにより、論理レプリケーションに必要な情報が先行書き込みログ (WAL) に追加されます。詳細については、「クラスターパラメーターの設定」をご参照ください。
注意事項
スキーマ移行中、DTS はソースデータベースからターゲットデータベースに外部キーを移行しません。
完全データ移行および増分データ移行中、DTS はセッションレベルで制約チェックと外部キーのカスケード操作を一時的に無効にします。タスクの実行中にソースデータベースでカスケード更新または削除操作が発生した場合、データの不整合が発生する可能性があります。
タイプ | 説明 |
ソースデータベースの制限事項 |
|
その他の制限事項 |
|
課金
移行タイプ | インスタンス構成料金 | インターネットトラフィック料金 |
スキーマ移行と完全データ移行 | 無料。 | ターゲットデータベースのアクセス方法 パラメーターが パブリック IP アドレス に設定されている場合、インターネットトラフィックに対して課金されます。 詳細については、「課金の概要」をご参照ください。 |
増分データ移行 | 課金されます。詳細については、「課金の概要」をご参照ください。 |
移行タイプ
移行タイプ | 注 |
スキーマ移行 | DTS は、移行オブジェクトのスキーマ定義をターゲットデータベースに移行します。現在、DTS はテーブルのスキーマ移行をサポートしています。 |
完全データ移行 | DTS は、ソースデータベースから移行オブジェクトのすべての既存データをターゲットデータベースに移行します。 説明 スキーマ移行と完全データ移行が完了するまで、移行オブジェクトに対して DDL 操作を実行しないでください。そうしないと、移行が失敗する可能性があります。 |
増分データ移行 | 完全データ移行後、DTS はソースデータベースから REDO ログをポーリングしてキャプチャし、増分データをターゲットデータベースに移行します。 増分データ移行により、アプリケーションを停止することなくデータをスムーズに移行できます。 |
増分移行可能な SQL 操作
操作タイプ | SQL 操作文 |
DML | INSERT、UPDATE、DELETE 説明 データがターゲットの AnalyticDB for MySQL クラスターに書き込まれると、UPDATE 文は自動的に REPLACE INTO 文に変換されます。UPDATE 文がプライマリキーに対して実行される場合、UPDATE 文は DELETE 文と INSERT 文に変換されます。 |
データベースアカウントに必要な権限
データベース | 必要な権限 | アカウントの作成と権限付与 |
PolarDB for PostgreSQL (Oracle 互換) クラスター | 特権アカウント。 | 詳細については、「データベースアカウントの作成」をご参照ください。 |
AnalyticDB for MySQL V3.0 | 移行オブジェクトを含むターゲットデータベースに対する読み取りおよび書き込み権限。 | 詳細については、「データベースアカウントの作成」をご参照ください。 |
操作手順
ターゲットリージョンの移行タスクリストページに移動します。次のいずれかの方法を使用できます。
DTS コンソールから
左側のナビゲーションウィンドウで、データの移行 をクリックします。
ページの左上隅で、移行インスタンスが配置されているリージョンを選択します。
DMS コンソールから
説明実際の手順は、DMS コンソールのモードとレイアウトによって異なる場合があります。詳細については、「シンプルモードコンソール」および「DMS コンソールのレイアウトとスタイルをカスタマイズする」をご参照ください。
Data Management (DMS) コンソールにログインします。
上部のナビゲーションバーで、 を選択します。
データ移行タスク の右側で、移行インスタンスが配置されているリージョンを選択します。
タスクの作成 をクリックして、タスク構成ページに移動します。
ソースデータベースとターゲットデータベースを構成します。
警告ソースインスタンスとターゲットインスタンスを選択した後、ページの上部に表示される制限事項をよくお読みになることを推奨します。そうしないと、タスクが失敗したり、データの不整合が発生したりする可能性があります。
カテゴリ
構成
注
N/A
タスク名
DTS は自動的にタスク名を生成します。簡単に識別できるように、わかりやすい名前を指定することを推奨します。名前は一意である必要はありません。
ソースデータベース
データベースタイプ
PolarDB (Oracle と互換性) を選択します。
アクセス方法
クラウドインスタンス を選択します。
インスタンスリージョン
ソースの PolarDB for PostgreSQL (Oracle 互換) クラスターが配置されているリージョンを選択します。
インスタンス ID
ソースの PolarDB for PostgreSQL (Oracle 互換) クラスターのインスタンス ID を選択します。
データベース名
ソースの PolarDB for PostgreSQL (Oracle 互換) クラスター内の移行オブジェクトが属するデータベースの名前を入力します。
データベースアカウント
ソースの PolarDB for PostgreSQL (Oracle 互換) クラスターのデータベースアカウントを入力します。必要な権限については、「データベースアカウントに必要な権限」をご参照ください。
データベースパスワード
データベースアカウントのパスワードを入力します。
ターゲットデータベース
データベースタイプ
AnalyticDB MySQL 3.0 を選択します。
アクセス方法
クラウドインスタンス を選択します。
インスタンスリージョン
ターゲットの AnalyticDB for MySQL 3.0 データベースが配置されているリージョンを選択します。
インスタンス ID
ターゲットの AnalyticDB for MySQL 3.0 クラスターの ID を選択します。
データベースアカウント
ターゲットの AnalyticDB for MySQL 3.0 データベースのアカウントを入力します。詳細については、「データベースアカウントに必要な権限」をご参照ください。
データベースパスワード
データベースアカウントのパスワードを入力します。
構成が完了したら、ページ下部の 接続をテストして続行 をクリックします。
説明DTS サーバーからのアクセスを許可するために、DTS サービスの IP アドレスセグメントがソースおよびターゲットデータベースのセキュリティ設定に自動または手動で追加されていることを確認してください。詳細については、「DTS サーバーの IP アドレスをホワイトリストに追加する」をご参照ください。
ソースデータベースまたはターゲットデータベースが自己管理データベースの場合 (アクセス方法 が Alibaba Cloud インスタンス でない場合)、表示される DTS サーバーの CIDR ブロック ダイアログボックスで 接続テスト をクリックする必要もあります。
タスクオブジェクトを構成します。
オブジェクト設定 ページで、移行するオブジェクトを構成します。
構成
注
移行タイプ
要件と各エンジンでサポートされているタイプに基づいて移行タイプを選択します。
完全移行のみが必要な場合は、スキーマ移行 と 完全データ移行 の両方を選択します。
ダウンタイムなしで移行を実行するには、スキーマ移行、完全データ移行、および増分データ移行 を選択します。
説明スキーマ移行 を選択しない場合は、ターゲットデータベースにデータを受信するデータベースとテーブルが存在することを確認してください。また、必要に応じて 選択中のオブジェクト ボックスでオブジェクト名マッピング機能を使用してください。
増分データ移行 を選択しない場合は、データ整合性を確保するために、データ移行中にソースインスタンスに新しいデータを書き込まないでください。
競合するテーブルの処理モード
エラーの事前チェックと報告:ターゲットデータベースに同じ名前のテーブルが存在するかどうかをチェックします。同じ名前のテーブルが存在しない場合、事前チェック項目は合格します。同じ名前のテーブルが存在する場合、事前チェックフェーズでエラーが報告され、データ移行タスクは開始されません。
説明ターゲットデータベースのテーブルが同じ名前で、簡単に削除または名前変更できない場合は、ターゲットデータベースのテーブルの名前を変更できます。詳細については、「オブジェクト名マッピング」をご参照ください。
エラーを無視して続行:同じ名前のテーブルのチェックをスキップします。
警告エラーを無視して続行 を選択すると、データの不整合やビジネスリスクを引き起こす可能性があります。例:
テーブルスキーマが一致し、ターゲットデータベースのレコードがソースデータベースのレコードと同じプライマリキー値を持つ場合:
完全移行中、DTS はターゲットクラスターのレコードを保持します。ソースデータベースのレコードはターゲットデータベースに移行されません。
増分移行中、DTS はターゲットクラスターのレコードを保持しません。ソースデータベースのレコードがターゲットデータベースのレコードを上書きします。
テーブルスキーマが一致しない場合、データの一部の列のみが移行されるか、移行が失敗する可能性があります。注意して進めてください。
同期する DDL および DML 操作
インスタンスレベルで移行する DDL または DML 操作を選択します。サポートされている操作については、「増分移行可能な SQL 操作」をご参照ください。
説明テーブルレベルで増分移行の SQL 操作を選択するには、選択したオブジェクト セクションで移行オブジェクトを右クリックします。表示されるダイアログボックスで、移行する SQL 操作を選択します。
テーブルの結合
○ を選択すると、DTS は各テーブルに
__dts_data_source列を追加してデータソースを記録します。詳細については、「複数テーブルのマージを有効にする」をご参照ください。×:これはデフォルトのオプションです。
説明テーブルマージ機能はタスクレベルです。つまり、テーブルレベルでテーブルマージを実行することはできません。一部のテーブルをマージし、他のテーブルをマージしない場合は、2 つのデータ移行タスクを作成できます。
警告ソースデータベースまたはテーブルのスキーマを変更する DDL 操作を実行しないでください。そうしないと、データの不整合やタスクの失敗が発生する可能性があります。
移行先インスタンスでのオブジェクト名の大文字化
ターゲットインスタンスで移行されたオブジェクト (データベース、テーブル、列など) の英語名の大文字/小文字の区別ポリシーを構成できます。デフォルトでは、DTS のデフォルトポリシー が選択されています。ソースまたはターゲットデータベースのデフォルトポリシーと一致させることも選択できます。詳細については、「ターゲットデータベースのオブジェクト名の大文字/小文字の区別」をご参照ください。
ソースオブジェクト
ソースオブジェクト ボックスで、移行するオブジェクトをクリックし、
をクリックして 選択中のオブジェクト ボックスに移動します。重要移行タイプ で 増分データ移行 を選択した場合、データテーブルは 1 つしか選択できません。
移行タイプ で 増分データ移行 を選択しない場合、データベース、テーブル、および列を選択できます。
移行オブジェクトがデータベース全体である場合、デフォルトの動作は次のとおりです:
ソースデータベースの移行対象テーブルにプライマリキー (単一列のプライマリキーや複合プライマリキーなど) がある場合、プライマリキー列が分散キーとして使用されます。
ソースデータベースの移行対象テーブルにプライマリキーがない場合、ターゲットテーブルに自動採番主キー列が自動的に生成されます。これにより、ソースデータベースとターゲットデータベースの間でデータの不整合が発生する可能性があります。
選択中のオブジェクト
ターゲットインスタンスに移行するオブジェクトの名前を変更するには、選択したオブジェクト セクションでオブジェクトを右クリックします。詳細については、「個別のテーブル列マッピング」をご参照ください。
一度に複数のオブジェクトの名前を変更するには、[選択したオブジェクト] セクションの右上隅にある [一括編集] をクリックします。詳細については、「複数のオブジェクト名を一度にマッピングする」をご参照ください。
説明オブジェクト名マッピング機能を使用すると、名前が変更されたオブジェクトに依存する他のオブジェクトの移行が失敗する可能性があります。
データをフィルタリングするための WHERE 句を設定するには、選択中のオブジェクト セクションで移行するテーブルを右クリックします。表示されるダイアログボックスで、フィルター条件を設定します。詳細については、「フィルター条件の設定」をご参照ください。
データベースまたはテーブルレベルで移行する SQL 操作を選択するには、選択中のオブジェクト セクションで移行するオブジェクトを右クリックします。表示されるダイアログボックスで、移行する SQL 操作を選択します。
詳細設定へ をクリックして、詳細パラメーターを構成します。
構成
説明
タスクのスケジュールに使用する専用クラスターの選択
デフォルトでは、DTS は共有クラスターでタスクをスケジュールします。選択する必要はありません。より安定したタスクが必要な場合は、専用クラスターを購入して DTS 移行タスクを実行できます。
失敗した接続の再試行時間
移行タスクが開始された後、ソースまたはターゲットデータベースへの接続が失敗した場合、DTS はエラーを報告し、すぐに連続的なリトライ試行を開始します。デフォルトのリトライ時間は 720 分です。10 分から 1440 分の範囲でリトライ時間をカスタマイズすることもできます。30 分以上に設定することを推奨します。設定された時間内に DTS がソースおよびターゲットデータベースに再接続した場合、移行タスクは自動的に再開されます。そうでない場合、タスクは失敗します。
説明同じソースまたはターゲットを共有する複数の DTS インスタンスの場合、ネットワークリトライ時間は最後に作成されたタスクの設定によって決まります。
接続リトライ期間中もタスクは課金されるため、ビジネスニーズに基づいてリトライ時間をカスタマイズするか、ソースおよびターゲットデータベースインスタンスがリリースされた後できるだけ早く DTS インスタンスをリリースすることを推奨します。
移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。
移行タスクが開始された後、ソースまたはターゲットデータベースで接続以外の問題 (DDL または DML 実行例外など) が発生した場合、DTS はエラーを報告し、すぐに連続的なリトライ試行を開始します。デフォルトのリトライ時間は 10 分です。1 分から 1440 分の範囲でリトライ時間をカスタマイズすることもできます。10 分以上に設定することを推奨します。設定されたリトライ時間内に関連する操作が成功した場合、移行タスクは自動的に再開されます。そうでない場合、タスクは失敗します。
重要移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。 の値は、失敗した接続の再試行時間 の値より小さくする必要があります。
完全移行率を制限するかどうか
完全移行フェーズ中、DTS はソースデータベースとターゲットデータベースの一部の読み取りおよび書き込みリソースを消費するため、データベースの負荷が増加する可能性があります。必要に応じて、1 秒あたりのソースデータベースのクエリ率 QPS、1 秒あたりの完全移行の行数 RPS、および 1 秒あたりの完全移行データ量 (MB) BPS を設定して、ターゲットデータベースの負荷を軽減できます。
説明この設定項目は、移行タイプ で 完全データ移行 を選択した場合にのみ利用可能です。
移行インスタンスの実行後に 完全移行速度を調整することもできます。
増分移行率を制限するかどうか
必要に応じて、増分移行タスクに速度制限を設定することもできます。1 秒あたりの増分移行の行数 RPS および 1 秒あたりの増分移行データ量 (MB) BPS を設定して、ターゲットデータベースへの負荷を軽減できます。
説明この設定項目は、移行タイプ で 増分データ移行 を選択した場合にのみ利用可能です。
移行インスタンスの実行後に 増分移行速度を調整することもできます。
環境タグ
インスタンスを識別するために環境タグを選択できます。この例では必須ではありません。
ETL 機能の設定
抽出、変換、ロード (ETL) 機能を有効にするかどうかを選択します。詳細については、「ETL とは何か?」をご参照ください。有効な値:
○:ETL 機能を有効にします。コードエディタにデータ処理文を入力します。詳細については、「データ移行またはデータ同期タスクで ETL を構成する」をご参照ください。
×:ETL 機能を無効にします。
監視アラート
ビジネスニーズに基づいて、アラートを設定し、アラート通知を受け取るかどうかを選択します。
×:アラートを設定しません。
○:アラートを設定します。アラートしきい値とアラート通知も設定する必要があります。移行が失敗した場合や遅延がしきい値を超えた場合に、システムはアラート通知を送信します。
次へ: データ検証 をクリックして、データ検証タスクを構成します。
データ検証機能の詳細については、「データ検証の構成」をご参照ください。
任意: 前の構成が完了したら、次:データベースおよびテーブルのフィールド設定 をクリックします。 次に、ターゲットデータベースに移行するテーブルの タイプ、プライマリキー列の追加、配布キー、およびパーティションキーパラメーターを設定します。 パーティションキーパラメーターには、パーティションキー、パーティションルール、および パーティションのライフサイクル が含まれます。
説明このステップは、移行タイプ で スキーマ移行 を選択した場合にのみ利用可能です。変更するには、定義ステータス で すべて を選択します。
プライマリキー列の追加 フィールドでは、複数の列を選択して複合プライマリキーを構成できます。 複合プライマリキーの場合、1 つ以上の プライマリキー列の追加 を 配布キー および パーティションキー として選択する必要もあります。 詳細については、「CREATE TABLE」をご参照ください。
タスクを保存し、事前チェックを実行します。
API 操作の呼び出し時にこのインスタンスを設定するためのパラメーターを表示するには、次:タスク設定の保存と事前チェック ボタンにポインターを合わせ、表示される吹き出し内の OpenAPI パラメーターのプレビュー をクリックします。
API パラメーターを表示する必要がない場合、または表示が完了した場合は、ページ下部の 次:タスク設定の保存と事前チェック をクリックします。
説明移行タスクが開始される前に、事前チェックが実行されます。タスクは事前チェックに合格した後にのみ開始されます。
事前チェックが失敗した場合は、失敗したチェック項目の横にある 詳細を表示 をクリックし、プロンプトに基づいて問題を修正してから、再度事前チェックを実行します。
事前チェック中に警告が報告された場合:
無視できないチェック項目については、失敗した項目の横にある 詳細を表示 をクリックし、プロンプトに基づいて問題を修正してから、再度事前チェックを実行します。
無視でき、修正する必要がないチェック項目については、アラートの詳細を確認、無視、OK、再度事前チェックを実行 の順にクリックして、アラート項目をスキップし、事前チェックを再実行できます。アラート項目を無視すると、データの不整合などの問題が発生し、ビジネスにリスクをもたらす可能性があります。
インスタンスを購入します。
成功率 が 100% のときに、次:インスタンスの購入 をクリックします。
購入 ページで、データ移行インスタンスのリンク仕様を選択します。詳細については、次の表をご参照ください。
カテゴリ
パラメーター
説明
新しいインスタンスクラス
リソースグループの設定
インスタンスが属するリソースグループを選択します。デフォルト値はデフォルトリソースグループです。詳細については、「リソース管理とは何か?」をご参照ください。
インスタンスクラス
DTS は、異なるパフォーマンスレベルの移行仕様を提供します。リンク仕様は移行速度に影響します。ビジネスシナリオに基づいて仕様を選択できます。詳細については、「データ移行リンク仕様」をご参照ください。
構成が完了したら、Data Transmission Service (従量課金) 利用規約 を読んで選択します。
購入して起動 をクリックし、表示される OK ダイアログボックスで [OK] をクリックします。
データ移行タスク リストページで移行インスタンスの進行状況を表示できます。
説明移行インスタンスに増分移行タスクが含まれていない場合、インスタンスは自動的に停止し、そのステータスは完了になります。
移行インスタンスに増分移行タスクが含まれている場合、そのインスタンスは自動的に停止せず、増分移行タスクは実行を継続します。増分移行タスクが正常に実行されている間、インスタンスのステータスは実行中です。