TiCDC Avro プロトコル

Avro は、 アパッチアブロ™で定義され、 合流プラットフォームによってデフォルトのデータ交換形式として選択されたデータ交換形式プロトコルです。このドキュメントでは、TiDB 拡張フィールド、Avro データ形式の定義、および Avro とConfluent スキーマ レジストリ間の相互作用を含む、TiCDC での Avro データ形式の実装について説明します。

Avroを使用する

メッセージ キュー (MQ) をダウンストリーム シンクとして使用する場合、 sink-uriで Avro を指定できます。TiCDC は TiDB DML イベントをキャプチャし、これらのイベントから Avro メッセージを作成し、メッセージをダウンストリームに送信します。Avro はスキーマの変更を検出すると、最新のスキーマをスキーマ レジストリに登録します。

以下は Avro を使用した構成例です。

cdc cli changefeed create --server=http://127.0.0.1:8300 --changefeed-id="kafka-avro" --sink-uri="kafka://127.0.0.1:9092/topic-name?protocol=avro" --schema-registry=http://127.0.0.1:8081 --config changefeed_config.toml
[sink] dispatchers = [ {matcher = ['*.*'], topic = "tidb_{schema}_{table}"}, ]

--schema-registryは、 httpsプロトコルとusername:password認証をサポートします (例: --schema-registry=https://username:password@schema-registry-uri.com 。ユーザー名とパスワードは URL エンコードされている必要があります。

TiDB拡張フィールド

デフォルトでは、Avro は DML イベントで変更された行のデータのみを収集し、データ変更の種類や TiDB 固有の CommitTS (トランザクションの一意の識別子) は収集しません。この問題に対処するために、TiCDC は Avro プロトコル メッセージに次の 3 つの TiDB 拡張フィールドを導入します。7 でenable-tidb-extensiontrue ( sink-uriではfalse ) に設定されている場合、TiCDC はメッセージ生成中にこれらの 3 つのフィールドを Avro メッセージに追加します。

  • _tidb_op : DML タイプ。「c」は挿入を示し、「u」は更新を示します。
  • _tidb_commit_ts : トランザクションの一意の識別子。
  • _tidb_commit_physical_time : トランザクション識別子内の物理的なタイムスタンプ。

以下は設定例です。

cdc cli changefeed create --server=http://127.0.0.1:8300 --changefeed-id="kafka-avro-enable-extension" --sink-uri="kafka://127.0.0.1:9092/topic-name?protocol=avro&enable-tidb-extension=true" --schema-registry=http://127.0.0.1:8081 --config changefeed_config.toml
[sink] dispatchers = [ {matcher = ['*.*'], topic = "tidb_{schema}_{table}"}, ]

データ形式の定義

TiCDC は DML イベントを Kafka イベントに変換し、イベントのキーと値は Avro プロトコルに従ってエンコードされます。

キーデータ形式

{ "name":"{{TableName}}", "namespace":"{{Namespace}}", "type":"record", "fields":[ {{ColumnValueBlock}}, {{ColumnValueBlock}}, ] }
  • {{TableName}}イベントが発生したテーブルの名前を示します。
  • {{Namespace}} Avro の名前空間です。
  • {{ColumnValueBlock}}データの各列の形式を定義します。

キーのfieldsには、主キー列または一意のインデックス列のみが含まれます。

値データ形式

{ "name":"{{TableName}}", "namespace":"{{Namespace}}", "type":"record", "fields":[ {{ColumnValueBlock}}, {{ColumnValueBlock}}, ] }

デフォルトでは、値のデータ形式はキーのデータ形式と同じです。ただし、値のfieldsには主キー列だけでなく、すべての列が含まれます。

enable-tidb-extension有効にすると、値のデータ形式は次のようになります。

{ "name":"{{TableName}}", "namespace":"{{Namespace}}", "type":"record", "fields":[ {{ColumnValueBlock}}, {{ColumnValueBlock}}, { "name":"_tidb_op", "type":"string" }, { "name":"_tidb_commit_ts", "type":"long" }, { "name":"_tidb_commit_physical_time", "type":"long" } ] }

enable-tidb-extension無効になっている値データ形式と比較すると、 _tidb_op_tidb_commit_ts_tidb_commit_physical_time 3 つの新しいフィールドが追加されます。

カラムデータ形式

カラムデータは、キー/値データ形式の{{ColumnValueBlock}}部分です。TiCDC は、SQL タイプに基づいてカラムデータ形式を生成します。基本的なカラムデータ形式は次のとおりです。

{ "name":"{{ColumnName}}", "type":{ "connect.parameters":{ "tidb_type":"{{TIDB_TYPE}}" }, "type":"{{AVRO_TYPE}}" } }

1 つの列が NULL になる可能性がある場合、カラムのデータ形式は次のようになります。

{ "default":null, "name":"{{ColumnName}}", "type":[ "null", { "connect.parameters":{ "tidb_type":"{{TIDB_TYPE}}" }, "type":"{{AVRO_TYPE}}" } ] }
  • {{ColumnName}}列名を示します。
  • {{TIDB_TYPE}} TiDB 内の型を示します。これは SQL 型との 1 対 1 のマッピングではありません。
  • {{AVRO_TYPE}} アブロスペックの型を示します。
SQL タイプTIDB_タイプAVRO_タイプ説明
ブール内部整数
小さな内部整数符号なしの場合、TIDB_TYPE は INT UNSIGNED になります。
スモールイント内部整数符号なしの場合、TIDB_TYPE は INT UNSIGNED になります。
ミディアムミント内部整数符号なしの場合、TIDB_TYPE は INT UNSIGNED になります。
内部内部整数符号なしの場合、TIDB_TYPE は INT UNSIGNED になり、AVRO_TYPE は long になります。
ビッグイントビッグイント長さ符号なしの場合、TIDB_TYPE は BIGINT UNSIGNED です。1 avro-bigint-unsigned-handling-mode文字列の場合、AVRO_TYPE は文字列です。
タイニーブロブブロブバイト
  • ブロブブロブバイト
  • ミディアムブロブブロブバイト
  • ロングロブブロブバイト
  • バイナリブロブバイト
  • バイナリブロブバイト
  • 小さなテキストTEXT
  • TEXTTEXT
  • 中テキストTEXT
  • 長文TEXT
  • 文字TEXT
  • バルチャーTEXT
  • 浮く浮くダブル
  • ダブルダブルダブル
  • 日付日付
  • 日付時刻日付時刻
  • タイムスタンプタイムスタンプ
  • 時間時間
  • 整数
  • 少し少しバイト
  • 翻訳翻訳
  • 列挙列挙
  • セットセット
  • 小数点小数点バイトavro-decimal-handling-mode文字列の場合、AVRO_TYPE は文字列になります。

    Avro プロトコルでは、他の 2 つのsink-uriパラメータavro-decimal-handling-modeavro-bigint-unsigned-handling-modeもカラムデータ形式に影響する可能性があります。

    • avro-decimal-handling-mode 、Avro が 10 進数フィールドを処理する方法を制御します。これには以下が含まれます。

      • 文字列: Avro は小数フィールドを文字列として処理します。
      • precise: Avro は 10 進数フィールドをバイトとして処理します。
    • avro-bigint-unsigned-handling-mode 、Avro が BIGINT UNSIGNED フィールドを処理する方法を制御します。これには以下が含まれます。

      • 文字列: Avro は BIGINT UNSIGNED フィールドを文字列として処理します。
      • long: Avro は BIGINT UNSIGNED フィールドを 64 ビットの符号付き整数として処理します。値が9223372036854775807より大きい場合、オーバーフローが発生します。

    以下は設定例です。

    cdc cli changefeed create --server=http://127.0.0.1:8300 --changefeed-id="kafka-avro-string-option" --sink-uri="kafka://127.0.0.1:9092/topic-name?protocol=avro&avro-decimal-handling-mode=string&avro-bigint-unsigned-handling-mode=string" --schema-registry=http://127.0.0.1:8081 --config changefeed_config.toml
    [sink] dispatchers = [ {matcher = ['*.*'], topic = "tidb_{schema}_{table}"}, ]

    ほとんどの SQL タイプは、基本のカラムデータ形式にマップされます。その他の一部の SQL タイプは、基本データ形式を拡張して、より多くの情報を提供します。

    ビット(64)

    { "name":"{{ColumnName}}", "type":{ "connect.parameters":{ "tidb_type":"BIT", "length":"64" }, "type":"bytes" } }

    列挙/セット(a,b,c)

    { "name":"{{ColumnName}}", "type":{ "connect.parameters":{ "tidb_type":"ENUM/SET", "allowed":"a,b,c" }, "type":"string" } }

    10進数(10, 4)

    { "name":"{{ColumnName}}", "type":{ "connect.parameters":{ "tidb_type":"DECIMAL", }, "logicalType":"decimal", "precision":10, "scale":4, "type":"bytes" } }

    DDL イベントとスキーマの変更

    Avro は下流で DDL イベントを生成しません。DML イベントが発生するたびに、スキーマが変更されているかどうかを確認します。スキーマが変更されると、Avro は新しいスキーマを生成し、それをスキーマ レジストリに登録します。スキーマの変更が互換性チェックに合格しない場合、登録は失敗します。TiCDC はスキーマの互換性の問題を解決しません。

    スキーマの変更が互換性チェックに合格し、新しいバージョンが登録された場合でも、システムが正常に実行されるようにするには、データ プロデューサーとコンシューマーがアップグレードを実行する必要があることに注意してください。

    Confluent Schema Registry のデフォルトの互換性ポリシーがBACKWARDであると仮定し、ソース テーブルに空でない列を追加します。この状況では、Avro は新しいスキーマを生成しますが、互換性の問題により Schema Registry への登録に失敗します。この時点で、changefeed はエラー状態になります。

    スキーマの詳細については、 スキーマレジストリ関連ドキュメントを参照してください。

    トピックの分布

    スキーマ レジストリは、TopicNameStrategy、RecordNameStrategy、TopicRecordNameStrategy の 3 件名戦略をサポートしています。現在、TiCDC Avro は TopicNameStrategy のみをサポートしています。つまり、Kafka トピックは 1 つのデータ形式でのみデータを受信できます。したがって、TiCDC Avro では、複数のテーブルを同じトピックにマッピングすることは禁止されています。変更フィードを作成すると、トピック ルールに、構成された配布ルールの{schema}および{table}プレースホルダーが含まれていない場合、エラーが報告されます。

    互換性

    TiCDC クラスターを v7.0.0 にアップグレードする際、Avro を使用してレプリケートされたテーブルにFLOATデータ型が含まれている場合は、アップグレード前に Confluent Schema Registry の互換性ポリシーを手動でNoneに調整して、changefeed がスキーマを正常に更新できるようにする必要があります。そうしないと、アップグレード後に changefeed がスキーマを更新できず、エラー状態になります。詳細については、 #8490を参照してください。

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