Dumplingの概要
このドキュメントでは、データ エクスポート ツール - Dumplingを紹介します。 Dumplingは、TiDB/MySQL に保存されているデータを SQL または CSV データ ファイルとしてエクスポートし、論理的なフル バックアップまたはエクスポートの作成に使用できます。
レイテンシーの影響を受けない SST ファイル (キーと値のペア) のバックアップまたは増分データのバックアップについては、 ブラジルを参照してください。増分データのリアルタイム バックアップについては、 TiCDCを参照してください。
ノート:
PingCAP は以前、TiDB に固有の拡張機能を備えたmydumper プロジェクトのフォークを維持していました。このフォークはその後、Go で書き直されたDumplingに置き換えられ、TiDB に固有のより多くの最適化をサポートしています。 mydumper の代わりにDumplingを使用することを強くお勧めします。
Mydumperの概要については、 v4.0 Mydumper ドキュメントを参照してください。
Mydumper と比較したDumplingの改善点
- SQL や CSV など、複数の形式でのデータのエクスポートをサポート
- データのフィルタリングを容易にするテーブルフィルターつの機能をサポート
- Amazon S3 クラウド ストレージへのデータのエクスポートをサポートします。
- TiDB に対してさらに最適化が行われます。
- 単一のTiDB SQLステートメントのメモリ制限の構成をサポート
- TiDB v4.0.0 以降の TiDB GC 時間の自動調整をサポート
- TiDB の隠し列
_tidb_rowidを使用して、単一のテーブルからの同時データ エクスポートのパフォーマンスを最適化する - TiDB の場合、値
tidb_snapshotを設定して、データ バックアップの時点を指定できます。これにより、一貫性を確保するためにFLUSH TABLES WITH READ LOCKを使用する代わりに、バックアップの一貫性が確保されます。
Dumpling紹介
Dumplingは Go で書かれています。 Github プロジェクトはピンキャップ/餃子です。
Dumplingの詳細な使用方法については、 --helpオプションを使用するか、 Dumplingのオプション一覧を参照してください。
Dumplingを使用する場合は、実行中のクラスターで export コマンドを実行する必要があります。このドキュメントでは、 127.0.0.1:4000のホストに TiDB インスタンスがあり、この TiDB インスタンスにはパスワードのない root ユーザーがいると想定しています。
tiup install dumplingを実行すると、 TiUPを使用してDumplingを取得できます。その後、 tiup dumpling ...を使用してDumplingを実行できます。
Dumplingインストール パッケージはTiDB Toolkitに含まれています。 TiDB Toolkitをダウンロードするには、 TiDB ツールをダウンロードを参照してください。
TiDB/MySQL からのデータのエクスポート
必要な権限
- 選択する
- リロード
- ロックテーブル
- 複製クライアント
- 処理する
SQL ファイルへのエクスポート
Dumplingは、デフォルトでデータを SQL ファイルにエクスポートします。 --filetype sqlフラグを追加して、データを SQL ファイルにエクスポートすることもできます。
dumpling \
-u root \
-P 4000 \
-h 127.0.0.1 \
--filetype sql \
-t 8 \
-o /tmp/test \
-r 200000 \
-F 256MiB
上記のコマンドでは:
-h、-P、および-uオプションは、それぞれアドレス、ポート、およびユーザーを意味します。認証にパスワードが必要な場合は、-p $YOUR_SECRET_PASSWORDを使用してパスワードをDumplingに渡すことができます。
-oオプションは、ローカル ファイル パスまたは外部ストレージのURLをサポートするストレージのエクスポート ディレクトリを指定します。
-tオプションは、エクスポートのスレッド数を指定します。スレッドの数を増やすと、Dumplingの同時実行性とエクスポート速度が向上しますが、データベースのメモリ消費も増加します。そのため、あまり大きな数値を設定することはお勧めしません。通常は 64 未満です。-rオプションは、1 つのファイル内の最大行数を指定します。このオプションを指定すると、 Dumplingはテーブル内の同時実行性を有効にして、エクスポートを高速化し、メモリ使用量を削減します。アップストリーム データベースが TiDB v3.0 以降のバージョンの場合、このパラメーターの値が 0 より大きい場合、TiDB リージョン情報が分割に使用され、ここで指定した値が無効になることを示します。-Fオプションは、単一ファイルの最大サイズを指定するために使用されます (ここでの単位はMiBです5GiBや8KBなどの入力も受け入れられます)。 TiDB Lightningを使用してこのファイルを TiDB インスタンスにロードする予定がある場合は、その値を 256 MiB 以下に保つことをお勧めします。
ノート:
1 つのエクスポートされたテーブルのサイズが 10 GB を超える場合は、オプション
-rおよび-Fを使用することを強くお勧めします。
CSV ファイルにエクスポート
--filetype csv引数を追加することで、データを CSV ファイルにエクスポートできます。
データを CSV ファイルにエクスポートする場合、 --sql <SQL>を使用して SQL ステートメントでレコードをフィルタリングできます。たとえば、次のコマンドを使用して、 id < 100 in test.sbtest1に一致するすべてのレコードをエクスポートできます。
./dumpling \
-u root \
-P 4000 \
-h 127.0.0.1 \
-o /tmp/test \
--filetype csv \
--sql 'select * from `test`.`sbtest1` where id < 100' \
-F 100MiB \
--output-filename-template 'test.sbtest1.{{.Index}}'
上記のコマンドでは:
--sqlオプションは、CSV ファイルへのエクスポートにのみ使用できます。上記のコマンドは、エクスポートするすべてのテーブルでSELECT * FROM <table-name> WHERE id <100ステートメントを実行します。テーブルに指定されたフィールドがない場合、エクスポートは失敗します。
--sqlオプションを使用すると、Dumplingはエクスポートされたテーブルとスキーマの情報を取得できません。--output-filename-templateオプションを使用して CSV ファイルのファイル名形式を指定できます。これにより、後でTiDB Lightningを使用してデータ ファイルをインポートすることが容易になります。たとえば、--output-filename-template='test.sbtest1.{{.Index}}'は、エクスポートされた CSV ファイルの名前がtest.sbtest1.000000000またはtest.sbtest1.000000001であることを指定します。
--csv-separatorや--csv-delimiterなどのオプションを使用して、CSV ファイル形式を構成できます。詳細はDumplingのオプション一覧を参照してください。
ノート:
Dumplingでは、文字列とキーワードは区別されません。インポートされたデータがブール型の場合、値
trueは1に変換され、値falseは0に変換されます。
エクスポートされたファイルの形式
metadata: エクスポートされたファイルの開始時刻とマスター バイナリ ログの位置。cat metadataStarted dump at: 2020-11-10 10:40:19 SHOW MASTER STATUS: Log: tidb-binlog Pos: 420747102018863124 Finished dump at: 2020-11-10 10:40:20{schema}-schema-create.sql: スキーマの作成に使用される SQL ファイルcat test-schema-create.sqlCREATE DATABASE `test` /*!40100 DEFAULT CHARACTER SET utf8mb4 */;{schema}.{table}-schema.sql: テーブルの作成に使用される SQL ファイルcat test.t1-schema.sqlCREATE TABLE `t1` ( `id` int(11) DEFAULT NULL ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin;{schema}.{table}.{0001}.{sql|csv}: 日付ソース ファイルcat test.t1.0.sql/*!40101 SET NAMES binary*/; INSERT INTO `t1` VALUES (1);*-schema-view.sql、*-schema-trigger.sql、*-schema-post.sql: その他のエクスポートされたファイル
データを Amazon S3 クラウド ストレージにエクスポートする
v4.0.8 以降、 Dumplingはクラウド ストレージへのデータのエクスポートをサポートしています。データを Amazon の S3 バックエンド ストレージにバックアップする必要がある場合は、 -oパラメーターで S3 ストレージ パスを指定する必要があります。
指定されたリージョンに S3 バケットを作成する必要があります ( Amazon ドキュメント - S3 バケットを作成する方法を参照)。バケットにフォルダーも作成する必要がある場合は、 Amazon ドキュメント - フォルダーの作成を参照してください。
S3 バックエンド ストレージへのアクセス権限を持つアカウントのSecretKeyとAccessKeyを環境変数としてDumplingノードに渡します。
export AWS_ACCESS_KEY_ID=${AccessKey}
export AWS_SECRET_ACCESS_KEY=${SecretKey}
Dumplingは、 ~/.aws/credentialsからの資格情報ファイルの読み取りもサポートしています。 Dumplingの構成の詳細については、 外部ストレージの構成を参照してください。
Dumplingを使用してデータをバックアップする場合は、S3 ストレージのリージョンを意味する--s3.regionパラメータを明示的に指定します (たとえば、 ap-northeast-1 )。
./dumpling \
-u root \
-P 4000 \
-h 127.0.0.1 \
-r 200000 \
-o "s3://${Bucket}/${Folder}" \
--s3.region "${region}"
エクスポートされたデータをフィルタリングする
--whereオプションを使用してデータをフィルタリングする
Dumplingはデフォルトで、システム データベース ( mysql 、 sys 、 INFORMATION_SCHEMA 、 PERFORMANCE_SCHEMA 、 METRICS_SCHEMA 、およびINSPECTION_SCHEMAを含む) を除くすべてのデータベースをエクスポートします。 --where <SQL where expression>を使用して、エクスポートするレコードを選択できます。
./dumpling \
-u root \
-P 4000 \
-h 127.0.0.1 \
-o /tmp/test \
--where "id < 100"
上記のコマンドは、各テーブルからid < 100に一致するデータをエクスポートします。 --whereパラメータを--sqlと一緒に使用できないことに注意してください。
--filterオプションを使用してデータをフィルタリングする
Dumplingは、 --filterオプションでテーブル フィルターを指定することにより、特定のデータベースまたはテーブルをフィルター処理できます。テーブル フィルターの構文は.gitignoreの構文と似ています。詳細については、 テーブル フィルターを参照してください。
./dumpling \
-u root \
-P 4000 \
-h 127.0.0.1 \
-o /tmp/test \
-r 200000 \
--filter "employees.*" \
--filter "*.WorkOrder"
上記のコマンドは、 employeesのデータベース内のすべてのテーブルと、すべてのデータベース内のWorkOrderのテーブルをエクスポートします。
-Bまたは-Tオプションを使用してデータをフィルタリングする
Dumplingは、オプション-Bを使用して特定のデータベースをエクスポートしたり、オプション-Tを使用して特定のテーブルをエクスポートしたりすることもできます。
ノート:
- オプション
--filterとオプション-Tを同時に使用することはできません。-Tオプションは、database-name.table-nameのような完全な形式の入力のみを受け入れることができ、テーブル名のみの入力は受け入れられません。例:Dumplingは-T WorkOrderを認識できません。
例:
-B employeesはemployeesデータベースをエクスポートします。-T employees.WorkOrderはemployees.WorkOrderテーブルをエクスポートします。
同時実行によるエクスポート効率の向上
エクスポートされたファイルは、デフォルトで./export-<current local time>ディレクトリに保存されます。一般的に使用されるオプションは次のとおりです。
-tオプションは、エクスポートのスレッド数を指定します。スレッドの数を増やすと、Dumplingの同時実行性とエクスポート速度が向上しますが、データベースのメモリ消費も増加します。そのため、あまり大きな数値を設定することはお勧めしません。-rオプションは、1 つのファイルの最大レコード数 (またはデータベース内の行数) を指定します。 Dumplingを有効にすると、テーブルの同時実行性が有効になり、大きなテーブルのエクスポート速度が向上します。アップストリーム データベースが TiDB v3.0 以降のバージョンの場合、このパラメーターの値が 0 より大きい場合、TiDB リージョン情報が分割に使用され、ここで指定した値が無効になることを示します。--compress gzipオプションを使用すると、ダンプを圧縮できます。これは、ストレージがボトルネックである場合、またはストレージ容量が懸念される場合に、データのダンプを高速化するのに役立ちます。これの欠点は、CPU 使用率の増加です。各ファイルは個別に圧縮されます。
上記のオプションを指定すると、 Dumplingのデータ エクスポート速度が向上します。
Dumpling のデータ整合性オプションを調整する
ノート:
ほとんどのシナリオでは、Dumplingの既定のデータ整合性オプションを調整する必要はありません (既定値は
autoです)。
Dumplingは--consistency <consistency level>オプションを使用して、「一貫性保証」のためにデータをエクスポートする方法を制御します。一貫性のためにスナップショットを使用する場合、 --snapshotオプションを使用して、バックアップするタイムスタンプを指定できます。次のレベルの一貫性を使用することもできます。
flush:FLUSH TABLES WITH READ LOCKを使用して、レプリカ データベースの DML および DDL 操作を一時的に中断し、バックアップ接続のグローバルな一貫性を確保し、binlog 位置 (POS) 情報を記録します。すべてのバックアップ接続がトランザクションを開始した後、ロックは解放されます。オフピーク時または MySQL レプリカ データベースでフル バックアップを実行することをお勧めします。snapshot: 指定されたタイムスタンプの一貫したスナップショットを取得してエクスポートします。lock: エクスポートするすべてのテーブルに読み取りロックを追加します。none: 一貫性を保証しません。auto: MySQL にはflush、TiDB にはsnapshotを使用します。
すべてが完了すると、エクスポートされたファイルが/tmp/testに表示されます。
ls -lh /tmp/test | awk '{print $5 "\t" $9}'
140B metadata
66B test-schema-create.sql
300B test.sbtest1-schema.sql
190K test.sbtest1.0.sql
300B test.sbtest2-schema.sql
190K test.sbtest2.0.sql
300B test.sbtest3-schema.sql
190K test.sbtest3.0.sql
TiDB の履歴データのスナップショットをエクスポートする
Dumplingは--snapshotオプション指定で特定のtidb_snapshotのデータをエクスポートできます。
--snapshotオプションは、TSO ( SHOW MASTER STATUSコマンドによるPositionフィールド出力) またはdatetimeデータ型の有効時間 ( YYYY-MM-DD hh:mm:ssの形式) に設定できます。次に例を示します。
./dumpling --snapshot 417773951312461825
./dumpling --snapshot "2020-07-02 17:12:45"
TSO が417773951312461825で時刻が2020-07-02 17:12:45のときの TiDB ヒストリカル データ スナップショットがエクスポートされます。
大きなテーブルのエクスポートのメモリ使用量を制御する
Dumplingが TiDB から大きな単一テーブルをエクスポートしている場合、エクスポートされたデータのサイズが大きすぎるためにメモリ不足 (OOM) が発生し、接続が中止され、エクスポートが失敗することがあります。次のパラメータを使用して、TiDB のメモリ使用量を削減できます。
- エクスポートするデータをチャンクに分割するには、
-rを設定します。これにより、TiDB のデータ スキャンのメモリ オーバーヘッドが削減され、同時テーブル データ ダンプが可能になり、エクスポートの効率が向上します。アップストリーム データベースが TiDB v3.0 以降のバージョンの場合、このパラメーターの値が 0 より大きい場合、TiDB リージョン情報が分割に使用され、ここで指定した値が無効になることを示します。 --tidb-mem-quota-queryの値を8589934592(8 GB) 以下に減らします。--tidb-mem-quota-queryは、TiDB での単一のクエリ ステートメントのメモリ使用量を制御します。--params "tidb_distsql_scan_concurrency=5"パラメータを調整します。tidb_distsql_scan_concurrencyは、TiDB でのスキャン操作の同時実行性を制御するセッション変数です。
大容量データ(1TB以上)エクスポート時のTiDB GC設定
TiDB からデータをエクスポートする (1 TB を超える) 場合、TiDB のバージョンが v4.0.0 以降で、かつDumplingが TiDB クラスターの PD アドレスにアクセスできる場合、 Dumplingは元のクラスターに影響を与えずに GC 時間を自動的に延長します。
他のシナリオでは、データ サイズが非常に大きい場合、エクスポート プロセス中の GC によるエクスポートの失敗を回避するために、事前に GC 時間を延長できます。
SET GLOBAL tidb_gc_life_time = '720h';
操作が完了したら、GC 時間を元に戻します (デフォルト値は10mです)。
SET GLOBAL tidb_gc_life_time = '10m';
最後に、エクスポートされたすべてのデータは、 TiDB Lightningを使用して TiDB にインポートして戻すことができます。
Dumplingのオプション一覧
| オプション | 使用法 | デフォルト値 | |
|---|---|---|---|
-Vまたは--version | Dumplingバージョンを出力し、直接終了します | ||
-Bまたは--database | 指定したデータベースをエクスポートする | ||
-Tまたは--tables-list | 指定したテーブルをエクスポートする | ||
-fまたは--filter | フィルター パターンに一致するテーブルをエクスポートします。フィルター構文については、 テーブルフィルターを参照してください。 | [\*.\*,!/^(mysql|sys|INFORMATION_SCHEMA|PERFORMANCE_SCHEMA|METRICS_SCHEMA|INSPECTION_SCHEMA)$/.\*] (システム スキーマを除くすべてのデータベースまたはテーブルをエクスポートします) | |
--case-sensitive | table-filter で大文字と小文字を区別するかどうか | false (大文字と小文字を区別しない) | |
-hまたは--host | 接続されたデータベース ホストの IP アドレス | 「127.0.0.1」 | |
-tまたは--threads | 同時バックアップ スレッドの数 | 4 | |
-rまたは--rows | 指定された行数でテーブルを行に分割します (通常、大きなテーブルを複数のファイルに分割する同時操作に適用されます。アップストリーム データベースが TiDB v3.0 以降のバージョンである場合、0 より大きいこのパラメーターの値は、 TiDB リージョン情報は分割に使用され、ここで指定した値は無効になります。 | ||
-Lまたは--logfile | ログ出力アドレス。空の場合、コンソールにログが出力されます | "" | |
--loglevel | ログレベル {debug,info,warn,error,dpanic, panic,fatal} | "情報" | |
--logfmt | ログ出力形式 {text,json} | "文章" | |
-dまたは--no-data | データをエクスポートしない (スキーマのみがエクスポートされるシナリオに適しています) | ||
--no-header | ヘッダーを生成せずにテーブルの CSV ファイルをエクスポートする | ||
-Wまたは--no-views | ビューをエクスポートしない | 真実 | |
-mまたは--no-schemas | データのみがエクスポートされたスキーマをエクスポートしないでください | ||
-sまたは--statement-size | INSERTステートメントのサイズを制御します。単位はバイトです | ||
-Fまたは--filesize | 分割されたテーブルのファイル サイズ。単位は128B 、 64KiB 、 32MiB 、および1.5GiBのように指定する必要があります。 | ||
--filetype | エクスポートされるファイルの種類 (csv/sql) | "SQL" | |
-oまたは--output | エクスポートされたローカル ファイルのパスまたは外部ストレージの URL | "./export-${time}" | |
-Sまたは--sql | 指定された SQL ステートメントに従ってデータをエクスポートします。このコマンドは、同時エクスポートをサポートしていません。 | ||
--consistency | フラッシュ: ダンプの前に FTWRL を使用します スナップショット: TSO の特定のスナップショットの TiDB データをダンプします lock: ダンプするすべてのテーブルで lock tables readを実行しますnone: 一貫性を保証できないロックを追加せずにダンプします。 auto: MySQL には --consistency フラッシュを使用します。 --consistency スナップショットを TiDB に使用する | 「オート」 | |
--snapshot | スナップショット TSO。 consistency=snapshotのときのみ有効 | ||
--where | where条件でテーブル バックアップの範囲を指定します | ||
-pまたは--password | 接続されたデータベース ホストのパスワード | ||
-Pまたは--port | 接続されたデータベース ホストのポート | 4000 | |
-uまたは--user | 接続されたデータベース ホストのユーザー名 | "根" | |
--dump-empty-database | 空のデータベースのCREATE DATABASEのステートメントをエクスポートします | 真実 | |
--ca | TLS接続用の認証局ファイルのアドレス | ||
--cert | TLS接続用のクライアント証明書ファイルのアドレス | ||
--key | TLS接続用のクライアント秘密鍵ファイルのアドレス | ||
--csv-delimiter | CSVファイルの文字型変数の区切り文字 | '"' | |
--csv-separator | CSV ファイルの各値の区切り記号。デフォルトの「,」を使用することはお勧めしません。 「 | + | 」を使用することをお勧めしますまたは他の珍しい文字の組み合わせ |
--csv-null-value | CSV ファイルでの null 値の表現 | 「\N」 | |
--escape-backslash | バックスラッシュ ( \ ) を使用して、エクスポート ファイル内の特殊文字をエスケープします | 真実 | |
--output-filename-template | golang テンプレートの形式で表されるファイル名テンプレート{{.DB}} 、 {{.Table}} 、および{{.Index}}の引数をサポート3 つの引数は、データ ファイルのデータベース名、テーブル名、およびチャンク ID を表します。 | '{{.DB}}.{{.Table}}.{{.Index}}' | |
--status-addr | Dumpling のサービス アドレス (Prometheus がメトリクスをプルし、デバッグを pprof するためのアドレスを含む) | ":8281" | |
--tidb-mem-quota-query | Dumplingコマンドの 1 行で SQL ステートメントをエクスポートする際のメモリ制限で、単位はバイトです。 v4.0.10 以降のバージョンでは、このパラメータを設定しない場合、TiDB はデフォルトでmem-quota-query構成項目の値をメモリ制限値として使用します。 v4.0.10 より前のバージョンでは、パラメーター値のデフォルトは 32 GB です。 | 34359738368 | |
--params | エクスポートするデータベースの接続のセッション変数を指定します。必要な形式は"character_set_client=latin1,character_set_connection=latin1"です |