GC 配置

你可以通过以下系统变量进行 GC 配置:

关于如何修改系统变量的值,请参考系统变量

流控

TiDB 支持 GC 流控,可通过配置 gc.max-write-bytes-per-sec 限制 GC worker 每秒数据写入量,降低对正常请求的影响,0 为关闭该功能。该配置可通过 tikv-ctl 动态修改:

  1. tikv-ctl --host=ip:port modify-tikv-config -n gc.max-write-bytes-per-sec -v 10MB

TiDB 5.0 引入的变化

在 TiDB 5.0 之前的版本中,GC 是通过系统表 mysql.tidb 进行配置的。从 TiDB 5.0 版本起,GC 仍然可以通过系统表 mysql.tidb 进行配置,但建议你使用系统变量进行配置,这样可以确保对配置的任何更改都能得到验证,防止造成异常行为 (#20655)。

TiDB 5.0 及之后的版本不再需要向各个 TiKV Region 都发送触发 GC 的请求,因此不再提供 CENTRAL GC 模式的支持,取而代之的是效率更高的 DISTRIBUTED GC 模式 (自 TiDB 3.0 起的默认 GC 模式)。

如果要了解 TiDB 历史版本中 GC 配置的变化信息,请使用左侧导航栏中的 “TIDB 版本选择器” 切换到本文档的历史版本。

TiDB 6.1.0 引入的变化

在 TiDB 6.1.0 之前的版本中,TiDB 内部事务不会影响 GC safe point 推进。从 TiDB 6.1.0 版本起,计算 safe point 时会考虑内部事务的 startTS,从而解决内部事务因访问的数据被清理掉而导致失败的问题。带来的负面影响是如果内部事务运行时间过长,会导致 safe point 长时间不推进,进而会影响业务性能。

TiDB v6.1.0 引入了系统变量 tidb_gc_max_wait_time 控制活跃事务阻塞 GC safe point 推进的最长时间,超过该值后 GC safe point 会强制向后推进。

GC in Compaction Filter 机制

GC in Compaction Filter 机制是在分布式 GC 模式 (DISTRIBUTED GC mode) 的基础上,由 RocksDB 的 Compaction 过程来进行 GC,而不再使用一个单独的 GC worker 线程。这样做的好处是避免了 GC 引起的额外磁盘读取,以及避免清理掉的旧版本残留大量删除标记影响顺序扫描性能。可以由 TiKV 配置文件中的以下开关控制:

  1. [gc]
  2. enable-compaction-filter = true

该 GC 机制可通过在线配置变更开启:

  1. show config where type = 'tikv' and name like '%enable-compaction-filter%';
  1. +------+-------------------+-----------------------------+-------+
  2. | Type | Instance | Name | Value |
  3. +------+-------------------+-----------------------------+-------+
  4. | tikv | 172.16.5.37:20163 | gc.enable-compaction-filter | false |
  5. | tikv | 172.16.5.36:20163 | gc.enable-compaction-filter | false |
  6. | tikv | 172.16.5.35:20163 | gc.enable-compaction-filter | false |
  7. +------+-------------------+-----------------------------+-------+
  1. set config tikv gc.enable-compaction-filter = true;
  2. show config where type = 'tikv' and name like '%enable-compaction-filter%';
  1. +------+-------------------+-----------------------------+-------+
  2. | Type | Instance | Name | Value |
  3. +------+-------------------+-----------------------------+-------+
  4. | tikv | 172.16.5.37:20163 | gc.enable-compaction-filter | true |
  5. | tikv | 172.16.5.36:20163 | gc.enable-compaction-filter | true |
  6. | tikv | 172.16.5.35:20163 | gc.enable-compaction-filter | true |
  7. +------+-------------------+-----------------------------+-------+

GC 配置 - 图1

注意

在使用 Compaction Filter 机制时,可能会出现 GC 进度延迟的情况,从而影响 TiKV 扫描性能。当你的负载中含有大量 coprocessor 请求,并且在 TiKV-Details > Coprocessor Detail 面板中发现 Total Ops Details 的 next()prev() 调用次数远远超过 processed_keys 调用的三倍时,可以采取以下措施:

  • 对于 TiDB v7.1.3 之前版本,建议尝试关闭 Compaction Filter,以加快 GC 速度。
  • 从 v7.1.3 开始,TiDB 会根据每个 Region 的冗余版本数量 region-compact-min-redundant-rows 和比例 region-compact-redundant-rows-percent 自动触发 compaction,从而提高 Compaction Filter 的 GC 速度。因此,在 v7.1.3 及之后的版本中,如果遇到上述情况,建议调整这两个参数,无需关闭 Compaction Filter。