データ移行を使用してデータを移行する

このガイドでは、データ移行 (DM) ツールを使用してデータを移行する方法を説明します。

ステップ1: DMクラスターをデプロイ

TiUPを使用してDMクラスタを展開するを推奨します。試用やテスト用にバイナリを使用してDMクラスタを展開するも使用できます。

注記:

  • すべての DM 構成ファイル内のデータベース パスワードについては、 dmctlで暗号化されたパスワードを使用することをお勧めします。データベース パスワードが空の場合は、暗号化する必要はありません。 dmctlを使用してデータベースパスワードを暗号化するを参照してください。
  • アップストリーム データベースとダウンストリーム データベースのユーザーには、対応する読み取り権限が必要です。

ステップ2: クラスター情報を確認する

TiUPを使用して DM クラスターを展開した後の構成情報は、以下のようになります。

  • DM クラスター内の関連コンポーネントの構成情報:

    成分ホストポート
    dm_worker1172.16.10.728262
    dm_worker2172.16.10.738262
    dm_マスター172.16.10.718261
  • アップストリームおよびダウンストリーム データベース インスタンスの情報:

    データベースインスタンスホストポートユーザー名暗号化されたパスワード
    アップストリーム MySQL-1172.16.10.813306VjX8cEeTX+qcvZ3bPaO4h0C80pe/1aU=
    アップストリーム MySQL-2172.16.10.823306VjX8cEeTX+qcvZ3bPaO4h0C80pe/1aU=
    ダウンストリーム TiDB172.16.10.834000

MySQL ホストで必要な権限のリストは、 事前チェックドキュメントに記載されています。

ステップ3: データソースを作成する

  1. MySQL-1関連の情報をconf/source1.yamlに書き込む:

    # MySQL1 Configuration. source-id: "mysql-replica-01" # This indicates that whether DM-worker uses Global Transaction Identifier (GTID) to pull binlog. Before you use this configuration item, make sure that the GTID mode is enabled in the upstream MySQL. enable-gtid: false from: host: "172.16.10.81" user: "root" password: "VjX8cEeTX+qcvZ3bPaO4h0C80pe/1aU=" port: 3306
  2. ターミナルで次のコマンドを実行し、 tiup dmctl使用して MySQL-1 データ ソース構成を DM クラスターにロードします。

    tiup dmctl --master-addr 172.16.10.71:8261 operate-source create conf/source1.yaml
  3. MySQL-2 の場合は、設定ファイル内の関連情報を変更し、同じdmctlコマンドを実行します。

ステップ4: データ移行タスクを構成する

次の例では、アップストリーム MySQL-1 インスタンスと MySQL-2 インスタンスの両方のtest_dbデータベースにあるtest_tableテーブルのデータすべてを、フル データと増分データ モードで TiDB のtest_dbデータベースにあるダウンストリームtest_tableテーブルに移行する必要があることを前提としています。

task.yamlタスク構成ファイルを以下のように編集します。

# The task name. You need to use a different name for each of the multiple tasks that # run simultaneously. name: "test" # The full data plus incremental data (all) migration mode. task-mode: "all" # The downstream TiDB configuration information. target-database: host: "172.16.10.83" port: 4000 user: "root" password: "" # Configuration of all the upstream MySQL instances required by the current data migration task. mysql-instances: - # The ID of upstream instances or the migration group. You can refer to the configuration of `source_id` in the "inventory.ini" file or in the "dm-master.toml" file. source-id: "mysql-replica-01" # The configuration item name of the block and allow lists of the name of the # database/table to be migrated, used to quote the global block and allow # lists configuration that is set in the global block-allow-list below. block-allow-list: "global" # Use black-white-list if the DM version is earlier than or equal to v2.0.0-beta.2. # The configuration item name of the dump processing unit, used to quote the global configuration of the dump unit. mydumper-config-name: "global" - source-id: "mysql-replica-02" block-allow-list: "global" # Use black-white-list if the DM version is earlier than or equal to v2.0.0-beta.2. mydumper-config-name: "global" # The global configuration of block and allow lists. Each instance can quote it by the # configuration item name. block-allow-list: # Use black-white-list if the DM version is earlier than or equal to v2.0.0-beta.2. global: do-tables: # The allow list of upstream tables to be migrated. - db-name: "test_db" # The database name of the table to be migrated. tbl-name: "test_table" # The name of the table to be migrated. # The global configuration of the dump unit. Each instance can quote it by the configuration item name. mydumpers: global: extra-args: ""

ステップ5: データ移行タスクを開始する

データ移行構成の潜在的なエラーを事前に検出するために、DM は事前チェック機能を提供します。

  • DM は、データ移行タスクを開始するときに、対応する権限と構成を自動的にチェックします。
  • check-taskコマンドを使用して、アップストリーム MySQL インスタンス構成が DM 要件を満たしているかどうかを手動で事前確認することもできます。

事前チェック機能の詳細については、 アップストリームのMySQLインスタンス構成を事前に確認する参照してください。

注記:

データ移行タスクを初めて開始する前に、アップストリームを構成する必要があります。そうしないと、タスクの開始時にエラーが報告されます。

tiup dmctlコマンドを実行してデータ移行タスクを開始します。3 task.yaml上記で編集した構成ファイルです。

tiup dmctl --master-addr 172.16.10.71:8261 start-task ./task.yaml
  • 上記のコマンドが次の結果を返す場合、タスクが正常に開始されたことを示します。

    { "result": true, "msg": "", "workers": [ { "result": true, "worker": "172.16.10.72:8262", "msg": "" }, { "result": true, "worker": "172.16.10.73:8262", "msg": "" } ] }
  • データ移行タスクを開始できない場合は、返されたプロンプトに従って構成を変更し、 start-task task.yamlコマンドを実行してタスクを再起動します。

ステップ6: データ移行タスクを確認する

タスクの状態を確認する必要がある場合、または特定のデータ移行タスクが DM クラスターで実行されているかどうかを確認する場合は、 tiup dmctlで次のコマンドを実行します。

tiup dmctl --master-addr 172.16.10.71:8261 query-status

ステップ7: データ移行タスクを停止する

データを移行する必要がなくなった場合は、 tiup dmctlで次のコマンドを実行してタスクを停止します。

tiup dmctl --master-addr 172.16.10.71:8261 stop-task test

testは、 task.yaml構成ファイルのname構成項目で設定したタスク名です。

ステップ8: タスクを監視してログを確認する

TiUP を使用して DM クラスターのデプロイメントとともに Prometheus、Alertmanager、および Grafana が正常にデプロイされ、Grafana アドレスが172.16.10.71であると仮定します。DM に関連するアラート情報を表示するには、ブラウザーでhttp://172.16.10.71:9093開いて Alertmanager に入ります。監視メトリックを確認するには、 http://172.16.10.71:3000に移動して DM ダッシュボードを選択します。

DM クラスターの実行中、DM-master、DM-worker、dmctl は監視メトリック情報をログに出力します。各コンポーネントのログ ディレクトリは次のとおりです。

  • DM マスター ログ ディレクトリ: --log-file DM マスター プロセス パラメータで指定します。DM がTiUP を使用して展開されている場合、ログ ディレクトリは DM マスター ノードの{log_dir}になります。
  • DM-worker ログ ディレクトリ: --log-file DM-worker プロセス パラメータで指定します。DM がTiUP を使用してデプロイされている場合、ログ ディレクトリは DM-worker ノードの{log_dir}になります。

このページは役に立ちましたか?