Data Transmission Service (DTS) を使用して、異なるAlibaba Cloudアカウントに属するApsaraDB for Redisインスタンス間で一方向のデータ同期を実行できます。 この機能は、リソースの移行やAlibaba Cloudアカウント間のマージ、ビジネスアーキテクチャの調整などのシナリオに適しています。
前提条件
ソースApsaraDB for RedisインスタンスがCommunity Editionインスタンスの場合、エンジンバージョンは4.0または5.0です。 ソースApsaraDB for RedisインスタンスがEnhanced Edition (Tair) インスタンスの場合、エンジンバージョンは5.0です。
説明ターゲットApsaraDB for Redisインスタンスのエンジンバージョンを4.0または5.0できます。 ターゲットApsaraDB for Redisインスタンスのエンジンバージョンは、ソースApsaraDB for Redisインスタンスのエンジンバージョンと同じかそれ以降である必要があります。 異なるエンジンバージョンを使用する2つのApsaraDB for Redisインスタンス間でデータを同期する前に、2つのバージョンの互換性を確認してください。 たとえば、従量課金方式を採用するApsaraDB For Redisインスタンスを作成して、ソースインスタンスとターゲットインスタンスの互換性を確認できます。 その後、このインスタンスをリリースするか、インスタンスの課金方法をサブスクリプションに変更できます。
ソースインスタンスまたはターゲットインスタンスは、クラスター、標準、または読み書き分離クラシックインスタンスです。
ソースインスタンスまたはターゲットインスタンスは、標準のクラウドネイティブインスタンスです。 クラスターcloud-nativeインスタンスは、ソースインスタンスまたはターゲットインスタンスとして設定できません。
ソースインスタンスは仮想プライベートクラウド (VPC) にデプロイされています。 ソースApsaraDB for Redisインスタンスがクラシックネットワークにデプロイされている場合、ネットワークタイプをVPCに変更できます。 詳細については、「クラシックネットワークからVPCへのネットワークタイプの切り替え」をご参照ください。
ソースインスタンスのSSL暗号化は無効です。 詳細については、「SSL暗号化の設定」をご参照ください。
ターゲットインスタンスの使用可能なストレージスペースが、ソースインスタンスのデータの合計サイズよりも大きいこと。
ソースインスタンスとターゲットインスタンス間の互換性を確保するには、ApsaraDB for Redis Enhanced Edition (Tair) インスタンスがソースインスタンスとして設定されている場合、ターゲットインスタンスはApsaraDB for Redis Enhanced Edition (Tair) インスタンスである必要があります。 これは、ApsaraDB for Redis Enhanced Edition (Tair) が、ApsaraDB for Redis Community Editionよりも多くのRedisモジュールと統合されているためです。
永続的なメモリ最適化インスタンスがソースインスタンスとして設定されている場合、appendonlyパラメーターはyesに設定されます。
ソースインスタンスは、ストレージに最適化されたApsaraDB for Redis Enhanced Edition (Tair) インスタンスではありません。 ストレージに最適化されたApsaraDB for Redis Enhanced Edition (Tair) インスタンスは、ターゲットインスタンスとしてのみ使用できます。
背景情報
この例では、2つのApsaraDB for Redisインスタンスが異なるAlibaba Cloudアカウントで作成されています。 アカウントAのインスタンスからアカウントBのインスタンスにデータを同期する必要があります。次の図は、同期ソリューションのアーキテクチャを示しています。
次の表に、このシナリオの一方向データ同期タスクを設定する方法を示します。
ステップ | 説明 |
1. ソースインスタンスが属するアカウントAを使用して、Resource Access Management (RAM) コンソールにログインし、RAMロールに必要な権限を付与します。 詳細については、このトピックの準備セクションを参照してください。 | RAMロールを設定するときは、アカウントBを信頼できるアカウントとして設定し、RAMロールにアカウントAのクラウドリソースへのアクセスを許可します。 |
2. 移行先インスタンスが属するアカウントBを使用してDTSコンソールにログインし、データ同期タスクを設定します。 詳細については、このトピックの「手順」をご参照ください。 | DTSは、Alibaba Cloudアカウント全体でソースApsaraDB for Redisインスタンスに関する情報を読み取ることができます。 |
サポートされているソースデータベースとターゲットデータベース
次の表は、DTSを使用して、Alibaba Cloudアカウント間でApsaraDB for Redisインスタンス間で一方向同期を実行する場合にサポートされるデータベースを示しています。
ソースデータベース | 宛先データベース |
|
|
制限事項
カテゴリ | 説明 |
ソースデータベースの制限 |
|
その他の制限 |
|
課金
同期タイプ | タスク設定料金 |
スキーマ同期と完全データ同期 | 無料です。 |
増分データ同期 | 有料。 詳細については、「課金の概要」をご参照ください。 |
同期できるコマンド
エディション | コマンド |
ApsaraDB for Redis Community Editionインスタンス |
|
ApsaraDB for Redis Enhanced Edition (Tair) インスタンス |
|
公開操作は同期できません。
EVALまたはEVALSHAコマンドを実行してLuaスクリプトを呼び出す場合、DTSはこれらのLuaスクリプトがターゲットインスタンスで実行されているかどうかを識別できません。 これは、増分データ同期中に、ターゲットインスタンスがLuaスクリプトの実行結果を明示的に返さないためです。
DTSがSYNCまたはPSYNCコマンドを実行してLISTタイプのデータを転送すると、DTSはターゲットインスタンスの既存のデータをクリアしません。 その結果、宛先インスタンスは重複するデータレコードを含むことがある。
準備
が必要です。 を取得します。IDソースインスタンスとターゲットインスタンスが属するAlibaba Cloudアカウントの
説明ソースインスタンスとターゲットインスタンスが属するAlibaba CloudアカウントのIDを取得した場合は、手順をスキップします。
ソースまたはターゲットインスタンスが属するAlibaba Cloudアカウントを使用してアカウント管理コンソールにログインします。
(オプション) 左側のナビゲーションウィンドウで、基本情報をクリックします。
の値を表示して記録します。アカウントIDパラメーターを使用します。
RAMロールを作成します。
左側のナビゲーションウィンドウで、を選択します。
ロールページで、ロールの作成をクリックします。
[ロールの作成] ページで、[信頼できるエンティティの選択] パラメーターを [Alibaba Cloudアカウント] に設定し、[次へ] をクリックします。
ロールの設定ステップで、RAMロールのパラメーターを設定します。
パラメーター
説明
RAM ロール名
RAM ロールの名前です。 この例では、ram-for-dtsが使用されます。
説明名前は 1~64 文字で、英字、数字、ハイフン (-) を使用できます。
注
オプションです。 RAMロールの説明。
信頼できる Alibaba Cloud アカウントの選択
[その他のAlibaba Cloudアカウント] を選択し、移行先インスタンスが属するAlibaba CloudアカウントのIDを入力します。
OKをクリックします。
作成したRAMロールに権限を付与します。
入力と添付をクリックします。
権限タブで、正確な許可をクリックします。
正確な許可パネルで、タイプをシステムポリシーに設定します。
ポリシー名フィールドで、AliyunDTSRolePolicyを入力します。
表示されるメッセージで、OK をクリックします。
閉じるをクリックします。
信頼ポリシーを変更します。
オプション。 [ロール] ページで、作成したRAMロールを見つけ、その名前をクリックします。
RAMロールの詳細ページで、信頼ポリシータブをクリックします。
信頼ポリシータブで、信頼ポリシーの編集をクリックします。
次のコードをコードエディターにコピーします。
{ "Statement": [ { "Action": "sts:AssumeRole", "Effect": "Allow", "Principal": { "RAM": [ "acs:ram::<Alibaba Cloud account ID>:root" ], "Service": [ "<Alibaba Cloud account ID>@dts.aliyuncs.com" ] } } ], "Version": "1" }
交換
<Alibaba CloudアカウントID>
上記のコードで、DTSタスクの作成に使用されるAlibaba CloudアカウントのIDを指定します。信頼ポリシードキュメントの保存をクリックします。
手順
ターゲットApsaraDB for Redisインスタンスが属するAlibaba Cloudアカウントを使用して、新しいDTSコンソールにログインし、[データ同期] ページに移動します。
データ管理 (DMS) コンソール にログインします。
上部のナビゲーションバーで、ポインタをDTSの上に移動します。
を選択します。
データ同期タスクの右側で、データ同期インスタンスが存在するリージョンを選択します。
説明新しいDTSコンソールを使用する場合は、上部のナビゲーションバーでデータ同期インスタンスが存在するリージョンを選択する必要があります。
[データ同期] ページで、[タスクの作成] をクリックします。 タスクの作成ウィザードで、ソースデータベースとターゲットデータベースを設定します。
警告ソースデータベースとターゲットデータベースを設定した後、ページに表示される制限を読むことを推奨します。 そうしないと、タスクが失敗したり、データの不一致が発生します。
セクション
パラメーター
説明
非該当
タスク名
DTSタスクの名前。 タスク名は自動生成されます。 タスクを簡単に識別できるように、わかりやすい名前を指定することをお勧めします。 一意のタスク名を指定する必要はありません。
ソースデータベース
既存のDMSデータベースインスタンスの選択
使用するインスタンス。 ビジネス要件に基づいて、既存のインスタンスを使用するかどうかを選択できます。
既存のインスタンスを選択すると、DTSはデータベースのパラメーターを自動的に入力します。
既存のインスタンスを選択しない場合は、ソースデータベースのパラメーターを設定する必要があります。
データベースタイプ
移行元ディスクのタイプを設定します。 [ApsaraDB for Redis Enhanced Edition (Tair)] を選択します。
アクセス方法
ソースデータベースのアクセス方法。 [Alibaba Cloudインスタンス] を選択します。
インスタンスリージョン
ソースApsaraDB for Redisインスタンスが存在するリージョン。
Alibaba Cloudアカウント全体でのデータの複製
Alibaba Cloudアカウント間でデータを同期するかどうかを指定します。 この例では、はいが選択されています。
説明2つのアカウントは、中国サイトのAlibaba Cloudアカウント (aliyun.com) と国際サイトのAlibaba Cloudアカウント (alibabacloud.com) です。
Alibaba Cloud アカウント
ソースApsaraDB for Redisインスタンスが属するAlibaba CloudアカウントのID。
説明Alibaba CloudアカウントのIDを取得するには、このアカウントを使用してアカウント管理コンソールにログインします。 アカウントIDは [基本情報] ページに表示されます。
RAMロール名
このトピックの準備セクションの手順に従って作成したRAMロールの名前。
インスタンスID
ソースApsaraDB for RedisインスタンスのID。
データベースパスワード
ソースApsaraDB for Redisインスタンスのデータベースパスワード。 パスワードに対応するデータベースアカウントには、読み取り権限が必要です。 パスワードを忘れた場合は、パスワードをリセットできます。 詳細については、「パスワードの変更またはリセット」をご参照ください。
ユーザー名がインスタンスIDと同じデフォルトアカウントを使用する場合は、パスワードのみを入力する必要があります。
カスタムアカウントを使用する場合は、
<custom account username >:< password>
形式でパスワードを指定します。 例: testaccount:Test1234。
説明このパラメーターはオプションで、ソースApsaraDB for Redisデータベースにデータベースパスワードが設定されていない場合は空のままにできます。
宛先データベース
既存のDMSデータベースインスタンスの選択
使用するインスタンス。 ビジネス要件に基づいて、既存のインスタンスを使用するかどうかを選択できます。
既存のインスタンスを選択した場合、DTSはインスタンスのパラメーターを自動的に入力します。
既存のインスタンスを選択しない場合、ターゲットデータベースのパラメーターを設定する必要があります。
データベースタイプ
ターゲットデータベースのタイプ。 [ApsaraDB for Redis Enhanced Edition (Tair)] を選択します。
アクセス方法
ターゲットデータベースのアクセス方法。 [Alibaba Cloudインスタンス] を選択します。
インスタンスリージョン
ターゲットApsaraDB for Redisインスタンスが存在するリージョン。
インスタンスID
ターゲットApsaraDB for RedisインスタンスのID。
データベースパスワード
ターゲットApsaraDB for Redisインスタンスのデータベースパスワード。 パスワードに対応するデータベースアカウントには、読み取り権限が必要です。 パスワードを忘れた場合は、パスワードをリセットできます。 詳細については、「パスワードの変更またはリセット」をご参照ください。
ユーザー名がインスタンスIDと同じデフォルトアカウントを使用する場合は、パスワードのみを入力する必要があります。
カスタムアカウントを使用する場合は、
<custom account username >:< password>
形式でパスワードを指定します。 例: testaccount:Test1234。
ページの下部で、接続性をテストして続行をクリックします。
ソースまたはターゲットデータベースがAlibaba Cloudデータベースインスタンス (ApsaraDB RDS for MySQLインスタンスやApsaraDB for MongoDBインスタンスなど) の場合、DTSは自動的にDTSサーバーのCIDRブロックをインスタンスのホワイトリストに追加します。 ソースデータベースまたはターゲットデータベースがElastic Compute Service (ECS) インスタンスでホストされている自己管理データベースの場合、DTSサーバーのCIDRブロックがECSインスタンスのセキュリティグループルールに自動的に追加されます。ECSインスタンスがデータベースにアクセスできることを確認する必要があります。 データベースが複数のECSインスタンスにデプロイされている場合、DTSサーバーのCIDRブロックを各ECSインスタンスのセキュリティグループルールに手動で追加する必要があります。 ソースデータベースまたはターゲットデータベースが、データセンターにデプロイされているか、サードパーティのクラウドサービスプロバイダーによって提供される自己管理データベースである場合、DTSサーバーのCIDRブロックをデータベースのホワイトリストに手動で追加して、DTSがデータベースにアクセスできるようにする必要があります。 詳細については、「DTSサーバーのCIDRブロックの追加」トピックの「DTSサーバーのCIDRブロック」セクションをご参照ください。
警告DTSサーバーのCIDRブロックがデータベースまたはインスタンスのホワイトリスト、またはECSセキュリティグループルールに自動的または手動で追加されると、セキュリティリスクが発生する可能性があります。 したがって、DTSを使用してデータを同期する前に、潜在的なリスクを理解して認識し、次の対策を含む予防策を講じる必要があります。VPNゲートウェイ、またはSmart Access Gateway。
同期するオブジェクトと詳細設定を設定します。
パラメーター
説明
同期タイプ
同期タイプ。 デフォルトでは、増分データ同期が選択されています。 [フルデータ同期] も選択する必要があります。 事前チェックの後、DTSは選択したオブジェクトの既存のすべてのデータをソースデータベースからターゲットデータベースに同期します。 データは、その後の増分同期の基礎となる。
説明完全なデータ同期は、ApsaraDB for Redis Enhanced Edition (Tair) インスタンスでのみサポートされます。
同期トポロジ
データ同期タスクの同期トポロジ。 一方向同期 を選択します。
競合テーブルの処理モード
エラーの事前チェックと報告: ターゲットデータベースにデータが存在するかどうかを確認します。 ターゲットデータベースにデータが存在しない場合、事前チェックがパスされます。 ターゲットデータベースにデータが存在する場合、事前チェック中にエラーが返され、データ同期タスクを開始できません。
エラーを無視して続行: ターゲットデータベース内のオブジェクトデータの存在検査 チェックアイテム。
警告エラーを無視して続行 を選択した場合、移行元データベースのデータレコードが移行先データベースの同じキーを持つデータレコードを上書きするため、移行先データベースでデータ損失が発生する可能性があります。 作業は慎重に行ってください。
ソースオブジェクト
ソースオブジェクト セクションから1つ以上のオブジェクトを選択し、アイコンをクリックして 選択中のオブジェクト セクションにオブジェクトを追加します。
説明同期するオブジェクトとしてデータベースのみを選択できます。 同期するオブジェクトとしてキーを選択できません。
[選択済みオブジェクト]
DB 0からDB 255にデータを同期するデータベースを選択したり、同期するデータをプレフィックスでフィルタリングしたりする場合は、オブジェクト名マッピング機能またはフィルタリング機能を使用できます。 選択中のオブジェクト セクションで、同期するデータベースを右クリックします。 スキーマの編集 ダイアログボックスで、パラメーターを設定します。 詳細については、「オブジェクト名のマップ」および「フィルター条件の設定」をご参照ください。
説明一度に複数のオブジェクト名をマップすることはできません。
[次へ:詳細設定] をクリックして詳細設定を構成します。
データ検証設定
データ検証機能の設定方法の詳細については、「データ検証の設定」をご参照ください。
詳細設定
パラメーター
説明
アラートの設定
データ同期タスクのアラートを設定するかどうかを指定します。 タスクが失敗するか、同期レイテンシが指定されたしきい値を超えると、アラート送信先は通知を受け取ります。 有効な値:
No: アラートを有効にしません。
Yes: アラートを設定します。 この場合、アラートしきい値と アラート通知設定 詳細については、「モニタリングとアラートの設定」トピックの「DTSタスクを作成するときのモニタリングとアラートの設定」をご参照ください。
失敗した接続の再試行時間
失敗した接続のリトライ時間範囲。 データ同期タスクの開始後にソースデータベースまたはターゲットデータベースの接続に失敗した場合、DTSはその時間範囲内ですぐに接続を再試行します。 有効な値: 10 ~ 1440 単位は分です。 デフォルト値: 720 このパラメーターを30より大きい値に設定することを推奨します。 DTSが指定された時間範囲内にソースデータベースとターゲットデータベースに再接続すると、DTSはデータ同期タスクを再開します。 それ以外の場合、データ同期タスクは失敗します。
説明ソースまたはターゲットデータベースが同じである複数のデータ同期タスクに対して異なるリトライ時間範囲を指定した場合、最も短いリトライ時間範囲が優先されます。
DTSが接続を再試行すると、DTSインスタンスに対して課金されます。 業務要件に基づいて再試行時間範囲を指定することを推奨します。 ソースインスタンスとターゲットインスタンスがリリースされた後、できるだけ早くDTSインスタンスをリリースすることもできます。
移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。
その他の問題の再試行時間範囲。 たとえば、データ同期タスクの開始後にDDLまたはDML操作の実行に失敗した場合、DTSはその時間範囲内ですぐに操作を再試行します。 有効な値: 1 ~ 1440 単位は分です。 デフォルト値は 10 です。 このパラメーターを10より大きい値に設定することを推奨します。 指定された時間範囲内で失敗した操作が正常に実行されると、DTSはデータ同期タスクを再開します。 それ以外の場合、データ同期タスクは失敗します。
重要移行元データベースと移行先データベースで他の問題が発生した場合の、再試行までの待機時間です。 パラメーターの値は、失敗した接続の再試行時間 パラメーターの値よりも小さくする必要があります。
完全移行率を制限するかどうか
完全データ同期中、DTSはソースデータベースとターゲットデータベースの読み取りおよび書き込みリソースを使用します。 これにより、データベースサーバーの負荷が増加する可能性があります。 1 秒あたりのソースデータベースのクエリ率 QPS 、1 秒あたりの完全移行の行数 RPS、および1 秒あたりの完全移行データ量 (MB) BPS パラメーターを設定して、ターゲットデータベースサーバーの負荷を軽減できます。
説明このパラメーターは、同期タイプ パラメーターで 完全データ同期 が選択されている場合にのみ表示されます。
増分同期率を制限するかどうか
増分データ同期のスロットリングを有効にするかどうかを指定します。 ビジネス要件に基づいて、増分データ同期のスロットリングを有効にできます。 スロットリングを設定するには、1 秒あたりの増分同期の行数 RPSおよび1 秒あたりの増分同期データ量 (MB) BPS パラメーターを設定する必要があります。 これにより、移行先データベースサーバーの負荷が軽減されます。
環境タグ
DTSインスタンスを識別するために使用される環境タグ。 ビジネス要件に基づいて環境タグを選択できます。 この例では、環境タグは選択されていません。
移行先データベースキーの有効期限を延長する
ソースデータベースからターゲットデータベースに同期されたキーが有効なままになるまでの延長期間。 単位は秒です。 次のコマンドなどの特定のコマンドを使用する場合は、データの一貫性を確保するために、このパラメーターを600に設定することを推奨します。
EXPIRE key seconds PEXPIRE key milliseconds EXPIREAT key timestamp PEXPIREAT key timestampMs
ETL の設定
抽出、変換、および読み込み (ETL) 機能を有効にするかどうかを指定します。 詳細については、「ETLとは何ですか? 」をご参照ください。有効な値:
Yes: ETL機能を設定します。 コードエディターでデータ処理ステートメントを入力できます。 詳細については、「データ移行またはデータ同期タスクでのETLの設定」をご参照ください。
No: ETL機能を設定しません。
タスク設定を保存し、事前チェックを実行します。
関連するAPI操作を呼び出してDTSタスクを設定するときに指定するパラメーターを表示するには、ポインターを 次:タスク設定の保存と事前チェック に移動し、OpenAPI パラメーターのプレビュー をクリックします。
パラメーターを表示または表示する必要がない場合は、ページ下部の 次:タスク設定の保存と事前チェック をクリックします。
説明データ同期タスクを開始する前に、DTSは事前チェックを実行します。 データ同期タスクは、タスクが事前チェックに合格した後にのみ開始できます。
データ同期タスクが事前チェックに失敗した場合は、失敗した各項目の横にある [詳細の表示] をクリックします。 チェック結果に基づいて原因を分析した後、問題のトラブルシューティングを行います。 次に、プレチェックを再実行します。
事前チェック中にアイテムに対してアラートがトリガーされた場合:
アラートアイテムを無視できない場合は、失敗したアイテムの横にある [詳細の表示] をクリックして、問題のトラブルシューティングを行います。 次に、もう一度プレチェックを実行します。
アラート項目を無視できる場合は、[アラート詳細の確認] をクリックします。 [詳細の表示] ダイアログボックスで、[無視] をクリックします。 表示されたメッセージボックスで、[OK] をクリックします。 次に、[再度事前チェック] をクリックして、事前チェックを再度実行します。 アラート項目を無視すると、データの不整合が発生し、ビジネスが潜在的なリスクにさらされる可能性があります。
成功率が100% になるまで待ちます。 次に、[次へ: インスタンスの購入] をクリックします。
購入ページで、データ同期インスタンスの課金方法とインスタンスクラスのパラメーターを設定します。 下表にパラメーターを示します。
セクション
パラメーター
説明
新しいインスタンスクラス
Billing Method
サブスクリプション: データ同期インスタンスの作成時にサブスクリプションの料金を支払います。 サブスクリプションの課金方法は、長期使用の場合、従量課金の課金方法よりも費用対効果が高くなります。
従量課金: 従量課金インスタンスは1時間ごとに課金されます。 従量課金方法は、短期使用に適しています。 従量課金データ同期インスタンスが不要になった場合は、インスタンスをリリースしてコストを削減できます。
リソースグループの設定
データ同期インスタンスが属するリソースグループ。 デフォルト値: Default resource group 詳細については、「リソース管理とは 」をご参照ください。
インスタンスクラス
DTSは、同期速度が異なるインスタンスクラスを提供します。 ビジネス要件に基づいてインスタンスクラスを選択できます。 詳細については、「データ同期インスタンスのインスタンスクラス」をご参照ください。
サブスクリプション期間
サブスクリプションの課金方法を選択した場合は、サブスクリプション期間と作成するデータ同期インスタンスの数を指定します。 サブスクリプション期間は、1〜9か月、1年、2年、3年、または5年とすることができる。
説明このパラメーターは、サブスクリプション の課金方法を選択した場合にのみ使用できます。
データ伝送サービス (従量課金) サービス規約を読んで選択します。
[購入して開始] をクリックします。 表示されるダイアログボックスで、OK をクリックします。
タスクリストでタスクの進行状況を確認できます。