データ移行リレーログ

データ移行 (DM) リレー ログは、データベースの変更を記述するイベントを含む番号付きファイルの複数のセットと、使用されたすべてのリレー ログ ファイルの名前を含むインデックス ファイルで構成されます。

リレー ログを有効にすると、DM-worker はアップストリームbinlogをローカル構成ディレクトリに自動的に移行します (DM がTiUPを使用してデプロイされている場合、デフォルトの移行ディレクトリは<deploy_dir>/<relay_log>です)。 <relay_log>のデフォルト値はrelay-dirで、 アップストリームデータベースコンフィグレーションファイルで変更できます。 v5.4.0 以降では、 DMワーカー設定ファイルrelay-dirを通じてローカル構成ディレクトリを構成できます。これは、アップストリーム データベースの構成ファイルよりも優先されます。

ユーザーシナリオ

MySQL では、storageスペースが限られているため、最大保持時間に達すると、 binlogは自動的に消去されます。アップストリーム データベースがbinlogを消去すると、DM は消去されたbinlogをプルできず、移行タスクは失敗します。移行タスクごとに、DM はアップストリームに接続を作成し、 binlogをプルします。接続が多すぎると、アップストリーム データベースのワークロードが重くなる可能性があります。

リレー ログを有効にすると、同じアップストリーム データベースを持つ複数の移行タスクで、ローカル ディスクにプルされたリレー ログを再利用できます。これにより、アップストリーム データベースへの負荷が軽減されます

完全および増分データ移行タスク ( task-mode=all ) の場合、DM は最初に完全なデータを移行し、次にbinlogに基づいて増分移行を実行する必要があります。完全移行フェーズに時間がかかる場合、上流のbinlogが消去され、増分移行が失敗する可能性があります。この状況を回避するには、リレーログ機能を有効にして、DM がローカルディスクに十分なログを自動的に保持し、増分移行タスクが正常に実行されるようにします

通常はリレー ログを有効にすることをお勧めしますが、次の潜在的な問題に注意してください。

リレー ログはディスクに書き込む必要があるため、外部 IO および CPU リソースが消費されます。これにより、データ レプリケーション プロセス全体が長くなり、データ レプリケーションのレイテンシーが増加します。レイテンシの影響を受けやすいシナリオでは、リレー ログを有効にすることは推奨されません。

注記:

DM v2.0.7 以降のバージョンでは、リレー ログの書き込みが最適化されています。レイテンシーと CPU リソースの消費は比較的低くなっています。

リレーログを使用する

このセクションでは、リレー ログを有効化および無効化する方法、リレー ログの状態を照会する方法、リレー ログを消去する方法について説明します。

リレーログを有効または無効にする

  • v5.4.0 and later versions
  • versions between v2.0.2 (included) and v5.3.0 (included)
  • earlier than v2.0.2

v5.4.0 以降のバージョンでは、 enable-relaytrueに設定することでリレー ログを有効にできます。v5.4.0 以降では、上流データ ソースをバインドするときに、DM-worker はデータ ソースの構成でenable-relay項目をチェックします。 enable-relaytrueの場合、このデータ ソースに対してリレー ログ機能が有効になります。

詳しい設定方法についてはアップストリームデータベースコンフィグレーションファイルを参照してください。

さらに、 start-relayまたはstop-relayコマンドを使用してデータ ソースのenable-relay構成を動的に調整し、リレー ログイン時間を有効または無効にすることもできます。

start-relay -s mysql-replica-01
{ "result": true, "msg": "" }

注記:

DM v2.0.2 以降の DM v2.0.x および v5.3.0 では、ソース構成ファイルの構成項目enable-relayは無効になり、リレー ログを有効または無効にするにはstart-relaystop-relayのみを使用できます。DM は、 データソース構成の読み込みのときにenable-relay trueに設定されていることを検出した場合、次のメッセージを出力します。

Please use `start-relay` to specify which workers should pull relay log of relay-enabled sources.

コマンドstart-relayでは、指定されたデータ ソースのリレー ログを移行するために 1 つ以上の DM ワーカーを構成できますが、パラメータで指定された DM ワーカーは空いているか、アップストリーム データ ソースにバインドされている必要があります。次に例を示します。

start-relay -s mysql-replica-01 worker1 worker2
{ "result": true, "msg": "" }
stop-relay -s mysql-replica-01 worker1 worker2
{ "result": true, "msg": "" }

v2.0.2 より前の DM バージョン (v2.0.2 は含まない) では、DM ワーカーをアップストリーム データ ソースにバインドするときに、DM はソース構成ファイルの構成項目enable-relayをチェックします。3 がenable-relay true設定されている場合、DM はデータ ソースのリレー ログ機能を有効にします。

設定項目enable-relayの設定方法についてはアップストリームデータベースコンフィグレーションファイル参照してください。

リレーログのステータスを照会する

コマンドquery-status -sを使用して、リレー ログのステータスを照会できます。

query-status -s mysql-replica-01
期待される出力
{ "result": true, "msg": "", "sources": [ { "result": true, "msg": "no sub task started", "sourceStatus": { "source": "mysql-replica-01", "worker": "worker2", "result": null, "relayStatus": { "masterBinlog": "(mysql-bin.000005, 916)", "masterBinlogGtid": "09bec856-ba95-11ea-850a-58f2b4af5188:1-28", "relaySubDir": "09bec856-ba95-11ea-850a-58f2b4af5188.000001", "relayBinlog": "(mysql-bin.000005, 4)", "relayBinlogGtid": "09bec856-ba95-11ea-850a-58f2b4af5188:1-28", "relayCatchUpMaster": false, "stage": "Running", "result": null } }, "subTaskStatus": [ ] }, { "result": true, "msg": "no sub task started", "sourceStatus": { "source": "mysql-replica-01", "worker": "worker1", "result": null, "relayStatus": { "masterBinlog": "(mysql-bin.000005, 916)", "masterBinlogGtid": "09bec856-ba95-11ea-850a-58f2b4af5188:1-28", "relaySubDir": "09bec856-ba95-11ea-850a-58f2b4af5188.000001", "relayBinlog": "(mysql-bin.000005, 916)", "relayBinlogGtid": "", "relayCatchUpMaster": true, "stage": "Running", "result": null } }, "subTaskStatus": [ ] } ] }

リレーログの一時停止と再開

コマンドpause-relayを使用してリレー ログのプル プロセスを一時停止し、コマンドresume-relayを使用してプロセスを再開できます。これらの 2 つのコマンドを実行するときは、アップストリーム データ ソースのsource-idを指定する必要があります。次の例を参照してください。

pause-relay -s mysql-replica-01 -s mysql-replica-02
期待される出力
{ "op": "PauseRelay", "result": true, "msg": "", "sources": [ { "result": true, "msg": "", "source": "mysql-replica-01", "worker": "worker1" }, { "result": true, "msg": "", "source": "mysql-replica-02", "worker": "worker2" } ] }
resume-relay -s mysql-replica-01
期待される出力
{ "op": "ResumeRelay", "result": true, "msg": "", "sources": [ { "result": true, "msg": "", "source": "mysql-replica-01", "worker": "worker1" } ] }

リレーログを消去する

DM では、リレー ログを消去する方法として、手動消去と自動消去の 2 つの方法を提供しています。どちらの方法でも、アクティブなリレー ログは消去されません。

注記:

  • アクティブ リレー ログ: リレー ログはデータ移行タスクによって使用されています。アクティブ リレー ログは現在、Syncer ユニットでのみ更新および書き込みが行われます。すべてモードのデータ移行タスクが、データ ソースの消去で構成された有効期限よりも長い時間を完全なエクスポート/インポートに費やした場合、リレー ログは消去されます。

  • 期限切れのリレー ログ: リレー ログ ファイルの最終変更時刻と現在の時刻の差が、構成ファイルのexpiresフィールドの値よりも大きくなっています。

自動パージ

自動パージを有効にし、その戦略をソース構成ファイルで構成できます。次の例を参照してください。

# relay log purge strategy purge: interval: 3600 expires: 24 remain-space: 15
  • purge.interval

    • バックグラウンドでの自動パージの間隔(秒単位)。
    • デフォルトでは「3600」であり、バックグラウンド パージ タスクが 3600 秒ごとに実行されることを示します。
  • purge.expires

    • リレー ログ (リレー処理ユニットに以前に書き込まれ、現在実行中のデータ移行タスクによって使用されていないか、後で読み取られないログ) を自動バックグラウンド パージで消去されるまで保持できる時間数。
    • デフォルトでは「0」で、リレーログの更新時間に応じてデータの消去が実行されないことを示します。
  • purge.remain-space

    • 指定された DM ワーカー マシンが、自動バックグラウンド パージで安全にパージできるリレー ログをパージしようとする、残りのディスク領域の量 (GB 単位)。 0に設定すると、残りのディスク領域に応じてデータ パージは実行されません。
    • デフォルトでは「15」であり、使用可能なディスク容量が 15 GB 未満になると、DM マスターはリレー ログを安全に消去しようとします。

手動パージ

手動パージとは、dmctl が提供するpurge-relayコマンドを使用してsubdirとbinlog名を指定し、指定されたbinlogより前のすべてのリレー ログをパージすることを意味します。コマンドで-subdirオプションが指定されていない場合は、現在のリレー ログ サブディレクトリより前のすべてのリレー ログがパージされます。

現在のリレーログのディレクトリ構造が次のようになっていると仮定します。

$ tree . . |-- deb76a2b-09cc-11e9-9129-5242cf3bb246.000001 | |-- mysql-bin.000001 | |-- mysql-bin.000002 | |-- mysql-bin.000003 | `-- relay.meta |-- deb76a2b-09cc-11e9-9129-5242cf3bb246.000003 | |-- mysql-bin.000001 | `-- relay.meta |-- e4e0e8ab-09cc-11e9-9220-82cc35207219.000002 | |-- mysql-bin.000001 | `-- relay.meta `-- server-uuid.index $ cat server-uuid.index deb76a2b-09cc-11e9-9129-5242cf3bb246.000001 e4e0e8ab-09cc-11e9-9220-82cc35207219.000002 deb76a2b-09cc-11e9-9129-5242cf3bb246.000003
  • dmctl で次のpurge-relayコマンドを実行すると、 e4e0e8ab-09cc-11e9-9220-82cc35207219.000002/mysql-bin.000001より前のすべてのリレー ログ ファイル ( deb76a2b-09cc-11e9-9129-5242cf3bb246.000001のすべてのリレー ログ ファイル) が削除されます。 e4e0e8ab-09cc-11e9-9220-82cc35207219.000002deb76a2b-09cc-11e9-9129-5242cf3bb246.000003のファイルは保持されます。

    purge-relay -s mysql-replica-01 --filename mysql-bin.000001 --sub-dir e4e0e8ab-09cc-11e9-9220-82cc35207219.000002
  • dmctl で次のpurge-relayコマンドを実行すると、現在の ( deb76a2b-09cc-11e9-9129-5242cf3bb246.000003 ) ディレクトリのmysql-bin.000001より前のすべてのリレー ログ ファイル ( deb76a2b-09cc-11e9-9129-5242cf3bb246.000001e4e0e8ab-09cc-11e9-9220-82cc35207219.000002のすべてのリレー ログ ファイル) が削除されます。13 deb76a2b-09cc-11e9-9129-5242cf3bb246.000003ファイルは保持されます。

    purge-relay -s mysql-replica-01 --filename mysql-bin.000001

リレーログの内部機構

このセクションでは、リレーログの内部の仕組みを紹介します。

ディレクトリ構造

リレー ログのローカルstorageのディレクトリ構造の例:

<deploy_dir>/<relay_log>/ |-- 7e427cc0-091c-11e9-9e45-72b7c59d52d7.000001 | |-- mysql-bin.000001 | |-- mysql-bin.000002 | |-- mysql-bin.000003 | |-- mysql-bin.000004 | `-- relay.meta |-- 842965eb-091c-11e9-9e45-9a3bff03fa39.000002 | |-- mysql-bin.000001 | `-- relay.meta `-- server-uuid.index
  • subdir :

    • DM-worker は、アップストリーム データベースから移行されたbinlog を同じディレクトリに保存します。各ディレクトリはsubdirです。

    • subdir <Upstream database UUID>.<Local subdir serial number>の形式で名前が付けられます。

    • アップストリームでプライマリインスタンスとセカンダリインスタンスが切り替わると、DM-worker は増分シリアル番号を持つ新しいsubdirディレクトリを生成します。

    • 上記の例では、ディレクトリ7e427cc0-091c-11e9-9e45-72b7c59d52d7.000001の場合、 7e427cc0-091c-11e9-9e45-72b7c59d52d7アップストリーム データベース UUID であり、 000001ローカルsubdirシリアル番号です。

  • server-uuid.index : 現在利用可能なsubdirのディレクトリのリストを記録します。

  • relay.meta : 移行されたbinlogの情報を各subdirに格納します。たとえば、

    cat c0149e17-dff1-11e8-b6a8-0242ac110004.000001/relay.meta
    binlog-name = "mysql-bin.000010" # The name of the currently migrated binlog. binlog-pos = 63083620 # The position of the currently migrated binlog. binlog-gtid = "c0149e17-dff1-11e8-b6a8-0242ac110004:1-3328" # GTID of the currently migrated binlog.

    複数の GTID が存在する場合もあります。

    cat 92acbd8a-c844-11e7-94a1-1866daf8accc.000001/relay.meta
    binlog-name = "mysql-bin.018393" binlog-pos = 277987307 binlog-gtid = "3ccc475b-2343-11e7-be21-6c0b84d59f30:1-14,406a3f61-690d-11e7-87c5-6c92bf46f384:1-94321383,53bfca22-690d-11e7-8a62-18ded7a37b78:1-495,686e1ab6-c47e-11e7-a42c-6c92bf46f384:1-34981190,03fc0263-28c7-11e7-a653-6c0b84d59f30:1-7041423,05474d3c-28c7-11e7-8352-203db246dd3d:1-170,10b039fc-c843-11e7-8f6a-1866daf8d810:1-308290454"

DMがbinlogを受信する位置

  • DM は、保存されたチェックポイント (デフォルトではダウンストリームdm_metaスキーマ) から各移行タスクに必要な最も早い位置を取得します。この位置が後続の位置よりも後の場合、DM はこの位置から移行を開始します。

  • ローカルリレーログが有効である場合、つまりリレーログに有効なserver-uuid.indexsubdir 、およびrelay.metaファイルが含まれている場合、DM-worker はrelay.metaに記録された位置から移行を回復します。

  • 有効なローカルリレーログが存在しないが、アップストリームデータソース構成ファイルでrelay-binlog-nameまたはrelay-binlog-gtid指定されている場合:

    • 非 GTID モードでは、 relay-binlog-nameを指定すると、DM ワーカーは指定されたbinlogファイルから移行を開始します。
    • GTID モードでは、 relay-binlog-gtid指定されると、DM ワーカーは指定された GTID から移行を開始します。
  • 有効なローカル リレー ログがなく、DM 構成ファイルにrelay-binlog-nameまたはrelay-binlog-gtidが指定されていない場合:

    • 非 GTID モードでは、DM ワーカーは、各サブタスクが移行している最も古いbinlogから移行を開始し、最新のbinlogが移行されるまで移行を続けます。

    • GTID モードでは、DM ワーカーは、各サブタスクが移行している最も古い GTID から移行を開始し、最新の GTID が移行されるまで移行を続けます。

    注記:

    アップストリームリレーログがパージされるとエラーが発生します。この場合、移行の開始位置を指定するためにrelay-binlog-gtid設定する必要があります。

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