復元する

このステートメントは、 BACKUPステートメントによって以前に作成されたバックアップ アーカイブからの分散復元を実行します。

RESTOREステートメントはBRツールと同じエンジンを使用しますが、復元プロセスは別のBRツールではなく TiDB 自体によって実行されます。BR のすべての利点と注意事項もここで適用されます。特に、RESTORE は現在BR RESTOREACIDしていませんRESTORE実行する前に、次の要件が満たされていることを確認してください。

  • クラスターは「オフライン」であり、現在の TiDB セッションは復元されるすべてのテーブルにアクセスするための唯一のアクティブな SQL 接続です。
  • 完全な復元を実行する場合、既存のデータが上書きされ、データとインデックスの間に不整合が生じる可能性があるため、復元するテーブルがすでに存在していてはいけません。
  • 増分復元が実行されている場合、テーブルはバックアップが作成された時点のLAST_BACKUP番目のタイムスタンプとまったく同じ状態になっている必要があります。

RESTORE実行するには、 RESTORE_ADMINまたはSUPER権限が必要です。さらに、復元を実行する TiDB ノードとクラスター内のすべての TiKV ノードの両方に、宛先からの読み取り権限が必要です。

RESTOREステートメントはブロックしており、復元タスク全体が完了、失敗、またはキャンセルされた後にのみ終了します。 RESTOREを実行するには、長時間持続する接続を準備する必要があります。 タスクはKILL TIDB QUERYステートメントを使用してキャンセルできます。

一度に実行できるタスクBACKUPRESTORE 1 つだけです。同じ TiDBサーバー上でタスクBACKUPまたはRESTOREすでに実行されている場合、新しいタスクRESTOREの実行は、以前のタスクがすべて完了するまで待機します。

RESTORE 「tikv」storageエンジンでのみ使用できます。「unistore」エンジンでRESTORE使用すると失敗します。

概要

RestoreStmt
RESTOREBRIETablesFROMstringLitRestoreOption
BRIETables
DATABASE*DBName,TABLETableNameList
RestoreOption
CHECKSUM_CONCURRENCY=LengthNumCONCURRENCY=LengthNumCHECKSUM=BooleanLOAD_STATS=BooleanRATE_LIMIT=LengthNumMB/SECONDSEND_CREDENTIALS_TO_TIKV=BooleanWAIT_TIFLASH_READY=BooleanWITH_SYS_TABLE=Boolean
Boolean
NUMTRUEFALSE

バックアップアーカイブから復元

RESTORE DATABASE * FROM 'local:///mnt/backup/2020/04/';
+------------------------------+-----------+----------+---------------------+---------------------+ | Destination | Size | BackupTS | Queue Time | Execution Time | +------------------------------+-----------+----------+---------------------+---------------------+ | local:///mnt/backup/2020/04/ | 248665063 | 0 | 2020-04-21 17:16:55 | 2020-04-21 17:16:55 | +------------------------------+-----------+----------+---------------------+---------------------+ 1 row in set (28.961 sec)

上記の例では、すべてのデータはローカル ファイル システムのバックアップ アーカイブから復元されます。データは、すべての TiDB ノードと TiKV ノードに分散された/mnt/backup/2020/04/ディレクトリから SST ファイルとして読み取られます。

上記の結果の最初の行は次のように説明されます。

カラム説明
Destination読み取る先のURL
Sizeバックアップアーカイブの合計サイズ(バイト単位)
BackupTS(未使用)
Queue TimeRESTORE番目のタスクがキューに入れられたときのタイムスタンプ (現在のタイムゾーン)。
Execution TimeRESTOREのタスクの実行が開始されたときのタイムスタンプ (現在のタイム ゾーン)。

部分的な復元

復元するデータベースまたはテーブルを指定できます。バックアップ アーカイブにデータベースまたはテーブルが欠落している場合、それらは無視され、 RESTOREもせずに完了します。

RESTORE DATABASE `test` FROM 'local:///mnt/backup/2020/04/';
RESTORE TABLE `test`.`sbtest01`, `test`.`sbtest02` FROM 'local:///mnt/backup/2020/04/';

外部ストレージ

BR はS3 または GCS からのデータの復元をサポートしています。

RESTORE DATABASE * FROM 's3://example-bucket-2020/backup-05/';

URL 構文については外部ストレージサービスの URI 形式でさらに詳しく説明します。

資格情報を配布しないクラウド環境で実行する場合は、 SEND_CREDENTIALS_TO_TIKVオプションをFALSEに設定します。

RESTORE DATABASE * FROM 's3://example-bucket-2020/backup-05/' SEND_CREDENTIALS_TO_TIKV = FALSE;

パフォーマンスの微調整

RATE_LIMIT使用すると、TiKV ノードあたりの平均ダウンロード速度が制限され、ネットワーク帯域幅が削減されます。

復元が完了する前に、 RESTOREデフォルトでバックアップ ファイルのデータに対してチェックサムを実行し、正確性を検証します。 1 つのテーブルに対するチェックサム タスクのデフォルトの同時実行数は 4 ですが、 CHECKSUM_CONCURRENCYパラメータを使用して調整できます。 データ検証が不要であることが確実な場合は、 CHECKSUMパラメータをFALSEに設定してチェックを無効にすることができます。

統計がバックアップされている場合、復元時にデフォルトで復元されます。統計を復元する必要がない場合は、 LOAD_STATSパラメータをFALSEに設定できます。

システム権限テーブルはデフォルトで復元されます。システム権限テーブルを復元する必要がない場合は、 WITH_SYS_TABLEパラメータをFALSEに設定できます。

デフォルトでは、復元タスクは、 TiFlashレプリカが完全に作成されるまで待機せずに完了します。復元タスクを待機させる必要がある場合は、 WAIT_TIFLASH_READYパラメータをTRUEに設定できます。

RESTORE DATABASE * FROM 's3://example-bucket-2020/backup-06/' RATE_LIMIT = 120 MB/SECOND CONCURRENCY = 64 CHECKSUM = FALSE;

増分復元

増分復元を実行するための特別な構文はありません。TiDB は、バックアップ アーカイブが完全か増分かを認識し、適切なアクションを実行します。各増分復元を正しい順序で適用するだけです。

たとえば、次のようにバックアップ タスクが作成されたとします。

BACKUP DATABASE `test` TO 's3://example-bucket/full-backup' SNAPSHOT = 413612900352000; BACKUP DATABASE `test` TO 's3://example-bucket/inc-backup-1' SNAPSHOT = 414971854848000 LAST_BACKUP = 413612900352000; BACKUP DATABASE `test` TO 's3://example-bucket/inc-backup-2' SNAPSHOT = 416353458585600 LAST_BACKUP = 414971854848000;

復元時にも同じ順序を適用する必要があります。

RESTORE DATABASE * FROM 's3://example-bucket/full-backup'; RESTORE DATABASE * FROM 's3://example-bucket/inc-backup-1'; RESTORE DATABASE * FROM 's3://example-bucket/inc-backup-2';

MySQL 互換性

このステートメントは、MySQL 構文に対する TiDB 拡張です。

参照

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