すべてのプロダクト
Search
ドキュメントセンター

Data Transmission Service:ApsaraDB RDS for MySQL インスタンスから自己管理 Doris データベースへのデータ同期

最終更新日:Dec 24, 2025

Data Transmission Service (DTS) を使用すると、自己管理 MySQL データベースや ApsaraDB RDS for MySQL インスタンスなどの MySQL データベースから Doris データベースにデータを同期して、大規模なデータ分析要件を満たすことができます。このトピックでは、ソース ApsaraDB RDS for MySQL インスタンスから、ECS インスタンスにデプロイされたターゲット Doris データベースにデータを同期する方法を説明します。

前提条件

ターゲット Doris データベースが作成済みであること。このデータベースの利用可能なストレージ容量が、ソース RDS MySQL インスタンスの使用済みストレージ容量を超えていること。

説明

サポートされているソースデータベースとターゲットデータベースのバージョンについては、「データ同期ソリューションの概要」をご参照ください。

注意事項

タイプ

説明

ソースデータベースの制限

  • 同期対象のオブジェクトに関する要件:

    • 同期対象のすべてのテーブルにプライマリキーまたは一意制約がある場合:

      テーブルのフィールドが一意であることを確認してください。そうでない場合、ターゲットデータベースに重複データが含まれる可能性があります。

    • 同期オブジェクトにプライマリキーも一意制約もないテーブルが含まれる場合:

      インスタンスを設定する際、同期タイプ には スキーマ同期 を選択します。テーブル・列設定 ステップでは、これらのテーブルの エンジンの選択[duplicate] に設定します。そうしないと、インスタンスの障害やデータ損失が発生する可能性があります。

      説明

      スキーマ同期中、DTS はターゲットテーブルにフィールドを追加します。詳細については、「追加列」をご参照ください。

  • テーブルレベルでデータを同期し、マッピングテーブルや列名などのオブジェクトを編集する必要がある場合、1 つのタスクで最大 1,000 テーブルまで同期できます。この制限を超えると、タスクを送信した後にエラーが報告されます。この場合、テーブルを複数の同期タスクに分割するか、データベース全体を同期するようにタスクを設定してください。

  • バイナリログ:

    • バイナリロギングは、RDS for MySQL インスタンスではデフォルトで有効になっています。`binlog_row_image` パラメーターを `full` に設定する必要があります。そうしないと、事前チェックでエラーが報告され、データ同期タスクを開始できません。インスタンスパラメーターの設定方法の詳細については、「インスタンスパラメーターの設定」をご参照ください。

      重要
      • ソースインスタンスが自己管理 MySQL データベースの場合、バイナリロギングを有効にし、`binlog_format` パラメーターを `row` に、`binlog_row_image` パラメーターを `full` に設定する必要があります。

      • ソースの自己管理 MySQL データベースが、2 つのデータベースが互いにプライマリとセカンダリであるプライマリ/プライマリクラスターである場合、`log_slave_updates` パラメーターを有効にする必要があります。これにより、DTS がすべてのバイナリログを取得できるようになります。詳細については、「自己管理 MySQL データベースのデータベースアカウントを作成し、バイナリロギングを設定する」をご参照ください。

    • RDS for MySQL インスタンスのバイナリログを少なくとも 3 日間保持してください。7 日間の保持期間を推奨します。自己管理 MySQL データベースの場合、バイナリログを少なくとも 7 日間保持してください。保持期間が短いと、DTS がバイナリログを取得できないため、DTS タスクが失敗する可能性があります。極端な場合、データの不整合やデータ損失が発生する可能性があります。必要な期間より短いバイナリログ保持期間に起因する問題は、DTS サービスレベルアグリーメント (SLA) の対象外です。

      説明

      RDS for MySQL インスタンスのバイナリログの [保存期間] を設定する方法の詳細については、「ローカルログの自動削除」をご参照ください。

  • 初期スキーマ同期および初期完全データ同期中は、データベースまたはテーブルのスキーマを変更するデータ定義言語 (DDL) 操作を実行しないでください。そうしないと、データ同期タスクが失敗します。

    説明

    初期完全データ同期中、DTS はソースデータベースをクエリします。これによりメタデータロックが作成され、ソースデータベースでの DDL 操作がブロックされる可能性があります。

  • 同期インスタンスの実行中に、物理バックアップからのデータ復元やカスケード操作によって生成されたデータなど、バイナリログに記録されない操作によるデータ変更は、ターゲットデータベースに同期されません。

    説明

    これが発生した場合、ビジネス上許容されるのであれば、データを含むデータベースまたはテーブルを同期オブジェクトから削除し、再度追加することができます。詳細については、「同期オブジェクトの変更」をご参照ください。

  • ソースデータベースが MySQL バージョン 8.0.23 以降で、同期するデータに不可視列が含まれている場合、これらの列のデータが取得できないため、データ損失が発生する可能性があります。

    説明

    ALTER TABLE <table_name> ALTER COLUMN <column_name> SET VISIBLE; コマンドを実行して、不可視列を可視にできます。 詳細については、「不可視列」をご参照ください。

その他の制限

  • Doris データベースでは、Unique Key モデルまたは Duplicate Key モデルを使用するテーブルにのみデータを同期できます。Duplicate Key モデルを使用するターゲットテーブルにデータを同期し、次のいずれかの操作が発生した場合、ターゲットデータベースに重複データが存在する可能性があります。この場合、`_is_deleted`、`_version`、`_record_id` などの追加列に基づいてデータを重複排除できます。

    • データ同期インスタンスでリトライ操作が発生した。

    • データ同期インスタンスで再起動操作が実行された。

    • データ同期インスタンスの開始後、同じデータ行に対して 2 つ以上の DML 操作が実行された。

      説明

      ターゲットテーブルが Duplicate Key モデルを使用するテーブルの場合、DTS は UPDATE または DELETE 文を INSERT 文に変換します。

  • 選択中のオブジェクト ボックスでパラメーターを設定する場合、 bucket_count (バケット数) パラメーターのみを設定できます。

    説明

    bucket_count パラメーターの値は、正の整数でなければなりません。 デフォルト値は [auto] です。

  • データ同期中に、ターゲット Doris データベースにクラスターを作成しないでください。そうしないと、データ同期タスクが失敗します。失敗したデータ同期タスクを再開するには、データ同期インスタンスを再起動できます。

  • Doris データベースは、文字で始まるデータベース名とテーブル名のみをサポートします。同期したいデータベースまたはテーブルの名前が文字で始まらない場合は、オブジェクト名マッピング機能を使用してデータベースまたはテーブルの名前を変更する必要があります。

  • 同期したいオブジェクト (データベース、テーブル、列など) の名前に中国語の文字が含まれている場合は、オブジェクト名マッピング機能を使用してオブジェクトの名前を変更する必要があります。たとえば、名前を中国語から英語に変更できます。そうしないと、タスクが失敗する可能性があります。

  • 一度に複数の列を変更する DDL 操作や、同じテーブルに対する連続した DDL 操作はサポートされていません。

  • データ同期中に、Doris データベースにバックエンド (BE) ノードを追加しないでください。そうしないと、タスクが失敗します。失敗したデータ同期タスクを再開するには、データ同期インスタンスを再起動できます。

  • MySQL では、VARCHAR(M) データの型の M は文字長を表します。Doris データベースでは、VARCHAR(N) データの型の N はバイト長を表します。DTS のスキーマ同期機能を使用しない場合は、Doris データベースの VARCHAR フィールドの長さを MySQL データベースの VARCHAR フィールドの長さの 4 倍に設定することをお勧めします。

  • 初期完全データ同期中、DTS はソースデータベースとターゲットデータベースの読み取りおよび書き込みリソースを消費します。これにより、データベースサーバーの負荷が増加する可能性があります。データを同期する前に、データ同期がソースデータベースとターゲットデータベースのパフォーマンスに与える影響を評価してください。ソースデータベースとターゲットデータベースの CPU 負荷が 30% 未満の場合など、オフピーク時にデータを同期することを推奨します。

  • 初期完全データ同期中、同時 INSERT 操作により、ターゲットデータベースのテーブルに断片化が発生します。初期完全データ同期が完了した後、ターゲットデータベースの使用済みテーブルスペースのサイズは、ソースインスタンスのそれよりも大きくなります。

  • データ同期中に、pt-online-schema-change などのツールを使用して、ソースデータベースの同期対象オブジェクトに対してオンライン DDL 操作を実行しないでください。そうしないと、データ同期タスクが失敗します。

  • データ同期中は、DTS のみを使用してターゲットデータベースにデータを書き込むことを推奨します。これにより、ソースデータベースとターゲットデータベース間のデータの不整合を防ぐことができます。

  • RDS for MySQL インスタンスで常時暗号化 (EncDB) 機能が有効になっている場合、完全データ同期はサポートされません。

    説明

    TDE (透過的データ暗号化) が有効になっている RDS for MySQL インスタンスでは、スキーマ同期、完全データ同期、および増分データ同期がサポートされています。

  • インスタンスが失敗した場合、DTS ヘルプデスクは 8 時間以内にインスタンスの回復を試みます。回復プロセス中に、インスタンスの再起動やパラメーターの調整などの操作が実行される場合があります。

    説明

    パラメーターが調整される場合、DTS インスタンスのパラメーターのみが変更され、データベース内のパラメーターは変更されません。変更される可能性のあるパラメーターには、「インスタンスパラメーターの変更」で説明されているものが含まれますが、これらに限定されません。

特殊なケース

  • ソースデータベースが自己管理 MySQL データベースの場合:

    • 同期中にソースデータベースでプライマリ/セカンダリのスイッチオーバーが発生した場合、同期タスクは失敗します。

    • DTS のレイテンシは、ターゲットデータベースの最後に同期されたデータレコードのタイムスタンプと現在のタイムスタンプを比較することによって計算されます。ソースデータベースで長時間 DML 操作が実行されない場合、表示されるレイテンシが不正確になることがあります。表示されるレイテンシが高すぎる場合は、ソースデータベースで DML 操作を実行してレイテンシ情報を更新できます。

      説明

      データベース全体を同期することを選択した場合、ハートビートテーブルを作成することもできます。ハートビートテーブルは毎秒更新または書き込みされます。

    • DTS は、バイナリログのオフセットを進めるために、ソースデータベースで定期的に CREATE DATABASE IF NOT EXISTS `test` コマンドを実行します。

    • ソースデータベースが Amazon Aurora MySQL インスタンスまたは別のクラスターモードの MySQL インスタンスである場合、タスクに設定されたドメイン名または IP アドレスとその解決結果が常に読み取り/書き込み (RW) ノードアドレスを指していることを確認してください。そうしないと、同期タスクが期待どおりに実行されない可能性があります。

  • ソースデータベースが RDS for MySQL インスタンスの場合:

    • RDS for MySQL 5.6 の読み取り専用インスタンスなど、トランザクションログを記録しない RDS for MySQL インスタンスは、ソースとしてサポートされていません。

    • DTS は、バイナリログのオフセットを進めるために、ソースデータベースで定期的に CREATE DATABASE IF NOT EXISTS `test` コマンドを実行します。

課金

同期タイプタスク設定料金
スキーマ同期と完全データ同期無料です。
増分データ同期有料です。詳細については、「課金の概要」をご参照ください。

増分同期がサポートする SQL 操作

操作タイプ

SQL 文

DML

INSERT、UPDATE、および DELETE

DDL

  • ADD COLUMN

  • MODIFY COLUMN

  • CHANGE COLUMN

  • DROP COLUMN および DROP TABLE

  • TRUNCATE TABLE

  • RENAME TABLE

    重要

    RENAME TABLE 操作はデータの不整合を引き起こす可能性があります。たとえば、同期オブジェクトが特定のテーブルのみで、同期中にソースインスタンスでテーブル名を変更した場合、そのテーブルのデータはターゲットデータベースに同期されません。この問題を回避するには、データ同期タスクを設定する際に、テーブルが属するデータベース全体を同期オブジェクトとして選択してください。RENAME TABLE 操作の前後にテーブルが属するデータベースが両方とも同期オブジェクトに含まれていることを確認してください。

データベースアカウントに必要な権限

データベース

必要な権限

作成と権限付与の方法

ソース RDS MySQL インスタンス

同期対象オブジェクトに対する読み取りおよび書き込み権限

アカウントの作成 および アカウント権限の変更

ターゲット Doris データベース

USAGE_PRIV 権限と、次の読み取りおよび書き込み権限:SELECT_PRIV、LOAD_PRIV、ALTER_PRIV、CREATE_PRIV、および DROP_PRIV

認証と権限付与

説明

使用するソースデータベースアカウントが RDS MySQL コンソールで作成および権限付与されていない場合は、そのアカウントに REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW、および SELECT 権限があることを確認してください。

操作手順

  1. ターゲットリージョンのデータ同期タスクリストページに移動します。次のいずれかの方法を使用できます。

    DTS コンソールから

    1. DTS コンソールにログインします。

    2. 左側のナビゲーションウィンドウで、データ同期 をクリックします。

    3. ページの左上隅で、同期インスタンスが配置されているリージョンを選択します。

    DMS コンソールから

    説明

    実際の操作は、DMS コンソールのモードとレイアウトによって異なる場合があります。詳細については、「シンプルモードコンソール」および「DMS コンソールのレイアウトとスタイルをカスタマイズする」をご参照ください。

    1. DMS コンソールにログインします。

    2. トップメニューバーから、[Data + AI] > [データ転送 (DTS)] > [データ同期] を選択します。

    3. データ同期タスク の右側で、同期インスタンスのリージョンを選択します。

  2. タスクの作成 をクリックすると、タスク構成ページに移動します。

  3. ソースデータベースとターゲットデータベースを設定します。次の表にパラメーターを示します。

    カテゴリ

    パラメーター

    説明

    N/A

    タスク名

    DTS は自動的にタスク名を生成します。簡単に識別できるように、わかりやすい名前を指定することを推奨します。名前は一意である必要はありません。

    移行元データベース

    既存の接続情報の選択

    • システムに登録されているデータベースインスタンス (新規作成または保存済み) を使用するには、ドロップダウンリストから目的のデータベースインスタンスを選択します。以下のデータベース情報は自動的に設定されます。

      説明

      DMS コンソールでは、この設定項目は DMS データベースインスタンスの選択 です。

    • データベースインスタンスをシステムに登録していない場合、または登録済みのインスタンスを使用する必要がない場合は、以下のデータベース情報を手動で設定します。

    データベースタイプ

    MySQL を選択します。

    アクセス方法

    Alibaba Cloud インスタンス を選択します。

    インスタンスのリージョン

    ソース ApsaraDB RDS for MySQL インスタンスが存在するリージョンを選択します。

    Alibaba Cloud アカウント間でデータを複製

    この例では、現在の Alibaba Cloud アカウント配下のデータベースインスタンスを使用するため、× を選択します。

    RDS インスタンス ID

    ソース ApsaraDB RDS for MySQL インスタンスの ID を選択します。

    データベースアカウント

    ソース ApsaraDB RDS for MySQL インスタンスのデータベースアカウント。アカウントに必要な権限の詳細については、「データベースアカウントに必要な権限」をご参照ください。

    データベースのパスワード

    データベースアカウントに対応するパスワードを入力します。

    暗号化

    必要に応じて [非暗号化接続] または [SSL セキュア接続] を選択します。 これを [SSL セキュア接続] に設定した場合、事前に RDS for MySQL インスタンスの SSL 暗号化を有効にする必要があります。 詳細については、「クラウド証明書を使用して SSL リンク暗号化をすばやく有効にする」をご参照ください。

    移行先データベース

    既存の接続情報の選択

    • システムに登録されているデータベースインスタンス (新規作成または保存済み) を使用するには、ドロップダウンリストから目的のデータベースインスタンスを選択します。以下のデータベース情報は自動的に設定されます。

      説明

      DMS コンソールでは、この設定項目はDMS データベースインスタンスの選択です。

    • データベースインスタンスをシステムに登録していない場合、または登録済みのインスタンスを使用する必要がない場合は、以下のデータベース情報を手動で設定します。

    データベースタイプ

    [Doris] を選択します。

    アクセス方法

    ターゲットデータベースのデプロイメントの場所に基づいて選択します。この例では、ECS 上の自己管理データベース を選択します。

    説明

    他の接続方法で自己管理データベースにアクセスする場合、対応する準備を完了する必要があります。詳細については、「事前準備」をご参照ください。

    インスタンスのリージョン

    ターゲット Doris データベースが存在するリージョンを選択します。

    ECS インスタンス ID

    ターゲット Doris データベースがデプロイされている ECS インスタンスの ID を選択します。

    説明

    ターゲット Doris データベースが複数の ECS インスタンスにデプロイされている場合 (たとえば、BE または FE ノードが他の ECS インスタンスにデプロイされている場合)、ノードがデプロイされている各 ECS インスタンスのセキュリティルールに DTS サーバーの CIDR ブロックを手動で追加する必要があります。

    ポート番号

    接続先の Doris データベースのサービスポートを入力します。デフォルト値:[9030]

    データベースアカウント

    ターゲット Doris データベースのデータベースアカウントを入力します。アカウントに必要な権限の詳細については、このトピックの「データベースアカウントに必要な権限」セクションをご参照ください。

    データベースのパスワード

    データベースアカウントに対応するパスワードを入力します。

  4. 構成が完了したら、ページの下部にある接続をテストして続行をクリックします。 DTS サーバーの CIDR ブロック ダイアログボックスで、接続テスト をクリックします。

    説明

    DTS サービスからのアクセスを許可するために、DTS サービスの IP アドレスブロックがソースデータベースとターゲットデータベースのセキュリティ設定に自動または手動で追加されていることを確認してください。詳細については、「DTS サーバーの IP アドレスホワイトリストを追加する」をご参照ください。

  5. タスクオブジェクトを設定します。

    1. オブジェクト設定 ページで、同期するオブジェクトを設定できます。

      設定

      説明

      同期タイプ

      [増分同期] はデフォルトで選択されています。また、[スキーマ同期][完全データ同期] も選択する必要があります。事前チェックが完了すると、DTS はソースインスタンスの完全データで宛先クラスターの同期オブジェクトを初期化します。このデータは、後続の増分同期のベースラインとなります。

      重要

      ApsaraDB RDS for MySQL インスタンスから自己管理の Doris データベースにデータを同期すると、データの型が変換されます。スキーマ同期 を選択しない場合、データ同期の前に、宛先の Doris データベースに Unique Key モデルまたは Duplicate key モデルを使用するテーブルを作成する必要があります。詳細については、「データ型のマッピング」、「追加の列」、および「Unique Key モデル」をご参照ください。

      競合するテーブルの処理モード

      • エラーの事前チェックと報告:ターゲットデータベースに同じ名前のテーブルがあるかどうかをチェックします。同じ名前のテーブルが見つかった場合、事前チェック中にエラーが報告され、データ同期タスクは開始されません。それ以外の場合、事前チェックは成功します。

        説明

        ターゲットデータベースで同じ名前のテーブルを削除または名前変更できない場合は、オブジェクト名マッピング機能を使用してターゲットデータベースのテーブル名を変更できます。詳細については、「オブジェクト名のマッピング」をご参照ください。

      • エラーを無視して続行: ターゲットデータベースにおける名前の競合チェックをスキップします。

        警告

        エラーを無視して続行 を選択すると、データに不整合が生じ、ビジネスが危険にさらされる可能性があります。たとえば、

        • テーブルスキーマが一致し、ターゲットデータベースのレコードがソースデータベースのレコードと同じプライマリキーまたは一意キーの値を持つ場合:

          • 完全データ同期中、DTS はターゲットクラスターのレコードを保持します。ソースデータベースの対応するレコードは同期されません。

          • 増分同期中、ソースデータベースのレコードがターゲットデータベースのレコードを上書きします。

        • テーブルスキーマが一致しない場合、データ初期化が失敗する可能性があります。これにより、一部の列のみの同期や完全な同期失敗が発生する可能性があります。注意して進めてください。

      移行先インスタンスでのオブジェクト名の大文字化

      宛先インスタンスのデータベース、テーブル、および列オブジェクト名の大文字/小文字のポリシーを設定できます。デフォルトでは、[DTS デフォルトポリシー] が選択されています。ソースデータベースまたはターゲットデータベースのデフォルトポリシーを選択することもできます。詳細については、「宛先オブジェクト名の大文字/小文字のポリシー」をご参照ください。

      ソースオブジェクト

      ソースオブジェクト ボックスでオブジェクトをクリックし、次に 向右 をクリックして 選択中のオブジェクト ボックスに移動します。

      説明

      同期するオブジェクトとしてデータベースまたはテーブルを選択します。

      選択中のオブジェクト

      • 宛先インスタンスの同期オブジェクトの名前を変更するには、選択中のオブジェクト ボックスでオブジェクトを右クリックします。詳細については、「オブジェクト名をマッピングする」をご参照ください。

      • 同期タイプスキーマ同期 を選択し、同期オブジェクトとしてテーブルを選択し、バケット数 (bucket_count パラメーター) を設定する必要がある場合は、選択中のオブジェクト ボックス内のテーブルを右クリックします。パラメーター設定 セクションで、パラメーター設定の有効化 に設定し、必要に応じて パラメーター値 パラメーターを設定してから、[OK] をクリックします。

      説明
      • データベースまたはテーブルレベルで同期する増分 SQL 操作を選択するには、選択中のオブジェクト ボックスで同期オブジェクトを右クリックし、表示されるダイアログボックスで目的の SQL 操作を選択します。

      • データをフィルターする WHERE 句を設定するには、選択中のオブジェクト ボックス内のテーブルを右クリックし、表示されるダイアログボックスでフィルター条件を設定します。詳細については、「フィルター条件を設定する」をご参照ください。

      • オブジェクト名マッピング機能を使用すると、マッピングされたオブジェクトに依存する他のオブジェクトの同期が失敗する可能性があります。

    2. 詳細設定へ をクリックします。

      パラメーター

      説明

      タスクのスケジュールに使用する専用クラスターの選択

      デフォルトでは、DTS は共有クラスターでタスクをスケジュールするため、選択する必要はありません。タスクの安定性を高めるために、DTS 同期タスクを実行するための専用クラスターを購入できます。詳細については、「DTS 専用クラスターとは何ですか?」をご参照ください。

      失敗した接続の再試行時間

      同期タスクの開始後にソースまたはターゲットデータベースへの接続が失敗した場合、DTS はエラーを報告し、すぐに接続のリトライを開始します。デフォルトのリトライ時間は 720 分です。リトライ時間を 10 分から 1,440 分の間の値にカスタマイズできます。30 分以上の設定を推奨します。指定されたリトライ時間内に DTS が再接続した場合、タスクは自動的に再開されます。それ以外の場合、タスクは失敗します。

      説明
      • 同じソースまたはターゲットを持つ複数の DTS インスタンス (DTS インスタンス A と DTS インスタンス B など) の場合、A のネットワークリトライ時間が 30 分、B が 60 分に設定されている場合、短い方の 30 分が適用されます。

      • DTS は接続リトライ中のタスク実行時間に対して課金するため、ビジネスニーズに基づいてリトライ時間をカスタマイズするか、ソースおよびターゲットデータベースインスタンスがリリースされた後できるだけ早く DTS インスタンスをリリースすることを推奨します。

      移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。

      同期タスクの開始後、ソースまたはターゲットデータベースで接続以外の問題 (DDL または DML 実行エラーなど) が発生した場合、DTS はエラーを報告し、すぐに連続的なリトライ操作を開始します。デフォルトのリトライ時間は 10 分です。リトライ時間を 1 分から 1,440 分の間の値にカスタマイズすることもできます。10 分以上の設定を推奨します。設定されたリトライ時間内に関連操作が成功した場合、同期タスクは自動的に再開されます。それ以外の場合、タスクは失敗します。

      重要

      移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。 の値は、失敗した接続の再試行時間 の値より小さくする必要があります。

      完全同期レートを制限するかどうか

      完全データ同期フェーズでは、DTS はソースデータベースとターゲットデータベースの読み取りおよび書き込みリソースを消費するため、負荷が増加する可能性があります。 ターゲットデータベースの負荷を軽減するには、1 秒あたりのソースデータベースのクエリ率 QPS1 秒あたりの完全移行の行数 RPS、および 1 秒あたりの完全移行データ量 (MB) BPS を設定して、完全データ同期タスクのレートを制限します。

      説明
      • この設定項目は、同期タイプ完全データ同期 に設定されている場合にのみ利用できます。

      • 同期インスタンスの実行後に、完全データ同期のレートを調整することもできます。

      増分同期率を制限するかどうか

      また、1 秒あたりの増分同期の行数 RPS1 秒あたりの増分同期データ量 (MB) BPS を設定することで、増分同期タスクにレート制限を設定し、ターゲットデータベースの負荷を軽減することもできます。

      順方向および逆方向タスクのハートビートテーブル SQL を削除

      ビジネスニーズに基づいて、DTS インスタンスの実行中にハートビート SQL 情報をソースデータベースに書き込むかどうかを選択します。

      • はい: ハートビート SQL 情報はソースデータベースに書き込まれません。これにより、DTS インスタンスが遅延をレポートする可能性があります。

      • いいえ:ソースデータベースにハートビート SQL 情報を書き込むため、ソースデータベースの物理バックアップやクローニングなどの機能に干渉する可能性があります。

      環境タグ

      インスタンスを識別するために使用される環境タグ。必要に応じて環境タグを選択できます。この例では、このパラメーターを設定する必要はありません。

      ETL 機能の設定

      抽出、変換、書き出し (ETL) 機能を有効にするかどうかを指定します。詳細については、「ETL とは何か?」をご参照ください。有効な値:

      監視アラート

      アラートを設定するかどうかを指定します。同期が失敗した場合、または遅延が指定されたしきい値を超えた場合、アラート連絡先に通知が送信されます。

    3. 任意: 前述の構成を完了した後、次:データベースおよびテーブルのフィールド設定 をクリックして、ターゲットデータベース内で同期するテーブルの プライマリキー列の追加配布キー、および エンジンの選択 を設定します。

      説明
      • このステップは、タスクオブジェクトを設定する際に 同期タイプスキーマ同期を選択した場合にのみ利用できます。定義ステータスすべてに設定して、設定を変更できます。

      • プライマリキー列の追加 に複数の列を選択して、複合プライマリキーを構成できます。プライマリキー列の追加 から 1 つ以上の列を 配布キー として選択する必要があります。

      • プライマリキーも一意制約も持たないテーブルについては、エンジンの選択[duplicate] に設定する必要があります。そうしないと、インスタンスで障害が発生したり、データが失われたりする可能性があります。

  6. タスクを保存し、事前チェックを実行します。

    • API 操作でこのインスタンスを設定するためのパラメーターを表示するには、次:タスク設定の保存と事前チェック ボタンにマウスポインターを合わせ、ツールチップに表示される OpenAPI パラメーターのプレビュー をクリックします。

    • API パラメーターの表示が完了したら、ページの下部にある次:タスク設定の保存と事前チェックをクリックします。

    説明
    • 同期ジョブが開始される前に、事前チェックが実行されます。ジョブは事前チェックに合格した後にのみ開始できます。

    • 事前チェックが失敗した場合は、失敗した項目の横にある詳細を表示をクリックし、プロンプトに従って問題を解決してから、事前チェックを再実行してください。

    • 事前チェック中に警告が生成された場合:

      • チェック項目が失敗し、無視できない場合は、項目の横にある詳細を表示をクリックします。その後、指示に従って問題を修正し、事前チェックを再実行します。

      • 無視できるチェック項目については、アラートの詳細を確認無視OK再度事前チェックを実行 の順にクリックして、警告をスキップし、事前チェックを再実行します。チェック項目の警告を無視すると、データの不整合などの問題が発生し、ビジネスにリスクをもたらす可能性があります。

  7. インスタンスを購入します。

    1. 成功率 が 100% になったら、次:インスタンスの購入 をクリックします。

    2. 購入 ページで、データ同期インスタンスの課金方法とリンク仕様を選択します。詳細については、次の表をご参照ください。

      カテゴリ

      パラメーター

      説明

      新しいインスタンスクラス

      課金方法

      • サブスクリプション:インスタンス作成時にお支払いいただきます。長期的なニーズに適しており、従量課金よりも手頃で、サブスクリプション期間が長いほど割引率が高くなります。

      • 従量課金:時間単位で課金されます。短期的なニーズに適しています。使用後すぐにインスタンスをリリースしてコストを節約できます。

      リソースグループの設定

      インスタンスが属するリソースグループ。デフォルトは [デフォルトリソースグループ] です。詳細については、「Resource Management とは」をご参照ください。

      リンク仕様

      DTS は、異なるパフォーマンスレベルの同期仕様を提供します。リンク仕様は同期レートに影響します。ビジネスシナリオに基づいて選択できます。詳細については、「データ同期リンク仕様」をご参照ください。

      サブスクリプション期間

      サブスクリプションモードでは、サブスクリプションインスタンスの期間と数量を選択します。月次サブスクリプションでは 1〜9 ヶ月、年次サブスクリプションでは 1、2、3、または 5 年から選択できます。

      説明

      このオプションは、課金方法がサブスクリプションの場合にのみ表示されます。

    3. 構成を完了した後、Data Transmission Service (従量課金) 利用規約 をお読みいただき、選択します。

    4. 購入して起動 をクリックし、OK ダイアログボックスで [OK] をクリックします。

      データ同期ページでタスクの進捗状況を確認できます。

データ型のマッピング

カテゴリ

ApsaraDB RDS for MySQL のデータ型

Doris のデータ型

数値

TINYINT

TINYINT

TINYINT UNSIGNED

SMALLINT

SMALLINT

SMALLINT

SMALLINT UNSIGNED

INT

MEDIUMINT

INT

MEDIUMINT UNSIGNED

BIGINT

INT

INT

INT UNSIGNED

BIGINT

BIGINT

BIGINT

BIGINT UNSIGNED

LARGEINT

BIT(M)

INT

Decimal

Decimal

説明

ZEROFILL はサポートされていません。

Numeric

Decimal

Float

Float

Double

DOUBLE

  • BOOL

  • BOOLEAN

BOOLEAN

日付と時刻

DATE

DATEV2

DATETIME[(fsp)]

DATETIMEV2

Timestamp[(fsp)]

DATETIMEV2

Time[(fsp)]

VARCHAR

YEAR[(4)]

INT

文字列

  • CHAR

  • VARCHAR

VARCHAR

重要

データ損失を避けるため、CHAR および VARCHAR(n) 型のデータは、ターゲット Doris データベースに同期された後、VARCHAR(4*n) に変換されます。

  • データの長さを指定しない場合、デフォルト値の VARCHAR(65533) が使用されます。

  • データ長が 65533 を超える場合、ターゲット Doris データベースに同期された後、STRING 型に変換されます。

  • BINARY

  • VARBINARY

STRING

  • TINYTEXT

  • TEXT

  • MEDIUMTEXT

  • LONGTEXT

STRING

  • TINYBLOB

  • BLOB

  • MEDIUMBLOB

  • LONGBLOB

STRING

ENUM

STRING

SET

STRING

JSON

STRING

追加列

追加列

説明

次の表は、DTS によって自動的に追加されるか、または Duplicate Key モデルを使用するターゲットテーブルに手動で追加する必要がある追加列について説明しています。

名前

データ型

デフォルト値

説明

_is_deleted

Int

0

データが削除されたかどうかを示します。

  • 挿入:値は 0 です。

  • 更新:値は 0 です。

  • 削除:値は 1 です。

_version

Bigint

0

  • 完全データの場合:値は 0 です。

  • 増分データの場合:値は、ソースデータベースのバイナリログ内の対応するタイムスタンプ (秒単位) です。

_record_id

Bigint

0

  • 完全データの場合:値は 0 です。

  • 増分データの場合:値は増分ログエントリのレコード ID であり、ログの一意の識別子です。

    説明

    ID 値は一意で自動インクリメントされます。