BACKUP

BACKUP 语句用于对 TiDB 集群执行分布式备份操作。

BACKUP 语句使用的引擎与 BR 相同,但备份过程是由 TiDB 本身驱动,而非单独的 BR 工具。BR 工具的优势和警告也适用于 BACKUP 语句。

执行 BACKUP 需要 SUPER 权限。此外,执行备份的 TiDB 节点和集群中的所有 TiKV 节点都必须有对目标存储的读或写权限。

BACKUP 语句开始执行后将会加锁,直到整个备份任务完成、失败或取消。因此,执行 BACKUP 时需要准备一个持久的连接。如需取消任务,可执行 KILL TIDB QUERY 语句。

一次只能执行一个 BACKUPRESTORE 任务。如果 TiDB server 上已经在执行一个 BACKUPRESTORE 语句,新的 BACKUP 将等待前面所有的任务完成后再执行。

语法图

  1. BackupStmt ::=
  2. "BACKUP" BRIETables "TO" stringLit BackupOption*
  3. BRIETables ::=
  4. "DATABASE" ( '*' | DBName (',' DBName)* )
  5. | "TABLE" TableNameList
  6. BackupOption ::=
  7. "RATE_LIMIT" '='? LengthNum "MB" '/' "SECOND"
  8. | "CONCURRENCY" '='? LengthNum
  9. | "CHECKSUM" '='? Boolean
  10. | "SEND_CREDENTIALS_TO_TIKV" '='? Boolean
  11. | "LAST_BACKUP" '='? BackupTSO
  12. | "SNAPSHOT" '='? ( BackupTSO | LengthNum TimestampUnit "AGO" )
  13. Boolean ::=
  14. NUM | "TRUE" | "FALSE"
  15. BackupTSO ::=
  16. LengthNum | stringLit

示例

备份数据库

  1. BACKUP DATABASE `test` TO 'local:///mnt/backup/2020/04/';
  1. +------------------------------+-----------+-----------------+---------------------+---------------------+
  2. | Destination | Size | BackupTS | Queue Time | Execution Time |
  3. +------------------------------+-----------+-----------------+---------------------+---------------------+
  4. | local:///mnt/backup/2020/04/ | 248665063 | 416099531454472 | 2020-04-12 23:09:48 | 2020-04-12 23:09:48 |
  5. +------------------------------+-----------+-----------------+---------------------+---------------------+
  6. 1 row in set (58.453 sec)

上述示例中,test 数据库被备份到本地,数据以 SST 文件的形式存储在分布于所有 TiDB 和 TiKV 节点的 /mnt/backup/2020/04/ 目录中。

输出结果的第一行描述如下:

列名 描述
Destination 目标存储的 URL
Size 备份文件的总大小,单位为字节
BackupTS 创建备份时的快照 TSO(用于增量备份
Queue Time BACKUP 任务开始排队的时间戳(当前时区)
Execution Time BACKUP 任务开始执行的时间戳(当前时区)

备份表

  1. BACKUP TABLE `test`.`sbtest01` TO 'local:///mnt/backup/sbtest01/';
  1. BACKUP TABLE sbtest02, sbtest03, sbtest04 TO 'local:///mnt/backup/sbtest/';

备份集群

  1. BACKUP DATABASE * TO 'local:///mnt/backup/full/';

注意,备份中不包含系统表 (mysql.*INFORMATION_SCHEMA.*PERFORMANCE_SCHEMA.* 等)。

外部存储

BR 支持备份数据到 Amazon S3 或 Google Cloud Storage (GCS):

  1. BACKUP DATABASE `test` TO 's3://example-bucket-2020/backup-05/?region=us-west-2&access-key={YOUR_ACCESS_KEY}&secret-access-key={YOUR_SECRET_KEY}';

有关详细的 URL 语法,见 BR 存储

当运行在云环境中时,不能分发凭证,可设置 SEND_CREDENTIALS_TO_TIKV 选项为 FALSE

  1. BACKUP DATABASE `test` TO 's3://example-bucket-2020/backup-05/?region=us-west-2'
  2. SEND_CREDENTIALS_TO_TIKV = FALSE;

性能调优

如果你需要减少网络带宽占用,可以通过 RATE_LIMIT 来限制每个 TiKV 节点的平均上传速度。

默认情况下,每个 TiKV 节点上运行 4 个备份线程。可以通过 CONCURRENCY 选项来调整这个值。

在备份完成之前,BACKUP 将对集群上的数据进行校验,以验证数据的正确性。如果你确信无需进行校验,可以通过 CHECKSUM 选项禁用这一步骤。

  1. BACKUP DATABASE `test` TO 's3://example-bucket-2020/backup-06/'
  2. RATE_LIMIT = 120 MB/SECOND
  3. CONCURRENCY = 8
  4. CHECKSUM = FALSE;

快照

可以指定一个时间戳、TSO 或相对时间,来备份历史数据。

  1. -- 相对时间
  2. BACKUP DATABASE `test` TO 'local:///mnt/backup/hist01'
  3. SNAPSHOT = 36 HOUR AGO;
  4. -- 时间戳(当前时区)
  5. BACKUP DATABASE `test` TO 'local:///mnt/backup/hist02'
  6. SNAPSHOT = '2020-04-01 12:00:00';
  7. -- TSO
  8. BACKUP DATABASE `test` TO 'local:///mnt/backup/hist03'
  9. SNAPSHOT = 415685305958400;

对于相对时间,支持以下时间单位:

  • MICROSECOND(微秒)
  • SECOND(秒)
  • MINUTE(分钟)
  • HOUR(小时)
  • DAY(天)
  • WEEK(周)

注意,相对时间的单位遵循 SQL 标准,永远使用单数。

增量备份

提供 LAST_BACKUP 选项,只备份从上一次备份到当前快照之间的增量数据。

  1. -- 时间戳(当前时区)
  2. BACKUP DATABASE `test` TO 'local:///mnt/backup/hist02'
  3. LAST_BACKUP = '2020-04-01 12:00:00';
  4. -- TSO
  5. BACKUP DATABASE `test` TO 'local:///mnt/backup/hist03'
  6. LAST_BACKUP = 415685305958400;

MySQL 兼容性

该语句是 TiDB 对 MySQL 语法的扩展。

另请参阅