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

Data Transmission Service:RDS for MySQL から ApsaraDB for SelectDB へのデータ同期

最終更新日:Dec 28, 2025

ApsaraDB for SelectDB は、大量データクエリに対するサブ秒の応答、最大 10,000 QPS の高同時実行ポイントクエリ、および高スループットの複雑な分析を提供します。Data Transmission Service (DTS) を使用すると、自己管理 MySQL データベースや RDS for MySQL インスタンスなどの MySQL データベースから ApsaraDB for SelectDB インスタンスにデータを同期して、大量データ分析のニーズに対応できます。このトピックでは、RDS for MySQL インスタンスを例に、その手順を説明します。

前提条件

宛先の ApsaraDB for SelectDB インスタンスを作成します。宛先インスタンスのストレージ容量は、ソースの RDS for 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 操作がブロックされる可能性があります。

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

    説明

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

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

    説明

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

その他の制限

  • 現在、SelectDB インスタンスでは Unique または Duplicate エンジンを使用するテーブルにのみデータを同期できます。

    ターゲットテーブルが Unique エンジンを使用する場合

    ターゲットテーブルが Unique エンジンを使用する場合、ターゲットテーブル内のすべての一意キーがソーステーブルにも存在し、同期オブジェクトに含まれていることを確認してください。そうでない場合、データ不整合が発生する可能性があります。

    Duplicate エンジンを使用する宛先テーブル

    ターゲットテーブルが Duplicate エンジンを使用する場合、以下の場合にターゲットデータベースでデータが重複する可能性があります。追加の列 (_is_deleted、_version、および _record_id) に基づいて重複を削除できます。

    • 同期インスタンスは再試行されました。

    • 同期インスタンスは再起動されました。

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

      説明

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

  • INDEX、PARTITION、VIEW、PROCEDURE、FUNCTION、TRIGGER、および FK の同期はサポートされていません。

  • 選択中のオブジェクト ボックスでパラメーターを設定する際、bucket_count パラメーターのみ設定できます。

    説明

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

  • データ同期中に、宛先の SelectDB インスタンスに新しいクラスターを作成しないでください。そうしないと、タスクが失敗します。同期インスタンスを再起動して、失敗したタスクを再開してみてください。

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

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

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

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

  • 複数のソーステーブルから単一のターゲットテーブルにデータを同期する複数テーブルのマージシナリオでは、ソーステーブルが同じスキーマを持っていることを確認してください。そうでない場合、データ不整合やタスクの失敗が発生する可能性があります。

  • MySQL では、VARCHAR(M) の M は文字長を示します。SelectDB では、VARCHAR(N) の N はバイト長を示します。DTS が提供するスキーマ同期機能を使用しない場合は、SelectDB の VARCHAR フィールドの長さを MySQL の VARCHAR フィールドの長さの 4 倍に設定することを推奨します。

  • DMS または gh-ost ツールを使用してソースでオンライン DDL 操作を実行する場合、DTS は元の DDL 文のみを宛先に同期します。このシナリオでは、DTS は大量の一時テーブルデータを同期する必要はありませんが、これにより宛先でテーブルがロックされる可能性があります。

    説明

    DTS は、pt-online-schema-change などのツールで行われたオンライン DDL 変更の同期をサポートしていません。ソースでそのような変更が存在する場合、宛先でデータが失われたり、同期インスタンスが失敗したりする可能性があります。

  • データを同期する前に、ソースデータベースとターゲットデータベースのパフォーマンスを評価してください。また、オフピーク時間中にデータ同期を実行することを推奨します。そうしないと、初期完全データ同期がソースデータベースとターゲットデータベースの読み取りおよび書き込みリソースを消費し、データベースの負荷が増加する可能性があります。

  • 初期完全データ同期は INSERT 操作を同時に実行します。これにより、ターゲットデータベースのテーブルに断片化が発生します。したがって、初期完全同期が完了した後、宛先インスタンスの表領域はソースインスタンスの表領域よりも大きくなります。

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

  • DTS 同期中に、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 for MySQL

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

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

宛先 SelectDB

クラスターアクセス権限 (Usage_priv) およびデータベースの読み取り・書き込み権限 (Select_priv、Load_priv、Alter_priv、Create_priv、Drop_priv)

権限管理 および 基本権限管理

説明

ソースデータベースアカウントが RDS for MySQL コンソールで作成および権限付与されていない場合、アカウントに REPLICATION CLIENT、REPLICATION SLAVE、SHOW VIEW、および SELECT 権限があることを確認する必要があります。

操作手順

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

    DTS コンソールから

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

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

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

    DMS コンソールから

    説明

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

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

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

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

  2. タスクの作成 をクリックして、タスク設定ページに移動します。

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

    カテゴリ

    設定

    説明

    なし

    タスク名

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

    移行元データベース

    既存の接続情報の選択

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

      説明

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

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

    データベースタイプ

    MySQL を選択します。

    アクセス方法

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

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

    ソース RDS for MySQL インスタンスが配置されているリージョンを選択します。

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

    この例では、同じ Alibaba Cloud アカウント内での同期を示します。× を選択します。

    RDS インスタンス ID

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

    データベースアカウント

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

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

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

    暗号化

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

    移行先データベース

    既存の接続情報の選択

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

      説明

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

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

    データベースタイプ

    [SelectDB] を選択します。

    アクセス方法

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

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

    宛先の SelectDB インスタンスが配置されているリージョンを選択します。

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

    この例では、同じ Alibaba Cloud アカウント内での同期を示します。× を選択します。

    インスタンス ID

    宛先の SelectDB インスタンスの ID を選択します。

    データベースアカウント

    宛先の SelectDB インスタンスのデータベースアカウントを入力します。必要な権限については、「データベースアカウントに必要な権限」をご参照ください。

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

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

  4. 設定が完了したら、ページ下部の 接続をテストして続行 をクリックします。

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

    • ソースまたはターゲットデータベースが自己管理データベースである場合 (アクセス方法Alibaba Cloud インスタンス ではない場合)、DTS サーバーの CIDR ブロック ダイアログボックスで 接続テスト をクリックする必要もあります。

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

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

      設定

      説明

      同期タイプ

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

      重要

      MySQL から SelectDB にデータを同期する際、データ型が変換されます。スキーマ同期 を選択しない場合は、事前に宛先の SelectDB インスタンスに対応するスキーマを持つ Unique または Duplicate モデルを使用するテーブルを作成する必要があります。詳細については、「データ型のマッピング」、「追加の列情報」、および「データモデル」をご参照ください。

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

      • エラーの事前チェックと報告:ターゲットデータベースに同じ名前のテーブルが存在するかどうかをチェックします。同じ名前のテーブルが存在しない場合、チェックは成功します。同じ名前のテーブルが存在する場合、事前チェックは失敗し、データ同期タスクは開始されません。

        説明

        ターゲットデータベースで同じ名前のテーブルを削除または名前変更できない場合は、ターゲットデータベースで別のテーブル名にマッピングできます。詳細については、「スキーマ、テーブル、および列のマッピング」をご参照ください。

      • エラーを無視して続行:ターゲットデータベース内の同じ名前のテーブルのチェックをスキップします。

        警告

        エラーを無視して続行 を選択すると、データ不整合が発生し、ビジネスにリスクをもたらす可能性があります。例:

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

        • テーブルスキーマが異なる場合、データの初期化に失敗したり、一部の列のデータしか同期できなかったり、同期が失敗したりする可能性があります。注意して進めてください。

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

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

      ソースオブジェクト

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

      説明

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

      選択中のオブジェクト

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

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

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

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

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

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

      設定

      説明

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

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

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

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

      説明
      • DTS インスタンス A と DTS インスタンス B のように、同じソースまたは宛先を持つ複数の DTS インスタンスの場合、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] をクリックします。

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

データ型のマッピング

カテゴリ

MySQL データ型

SelectDB データ型

数値

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) 型のデータは、SelectDB に同期された後、VARCHAR(4*n) に変換されます。

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

  • データ長が 65533 を超える場合、データは SelectDB に同期された後、STRING に変換されます。

  • BINARY

  • VARBINARY

STRING

  • TINYTEXT

  • TEXT

  • MEDIUMTEXT

  • LONGTEXT

STRING

  • TINYBLOB

  • BLOB

  • MEDIUMBOLB

  • LONGBLOB

STRING

ENUM

STRING

SET

STRING

JSON

STRING

追加の列情報

説明

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

名前

データ型

デフォルト値

説明

_is_deleted

Int

0

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

  • Insert:値は 0 です。

  • Update:値は 0 です。

  • Delete:値は 1 です。

_version

Bigint

0

  • 完全データ同期の場合、値は 0 です。

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

_record_id

Bigint

0

  • 完全データ同期の場合、値は 0 です。

  • 増分データ同期の場合、値は増分ログのレコード ID です。この ID はログの一意の識別子です。

    説明

    ID 値は一意で増加します。