Placement Rules in SQL

    注意

    Placement Rules in SQL 底层的实现依赖 PD 提供的放置规则 (placement rules) 功能,参考 Placement Rules 使用文档。在 Placement Rules in SQL 语境下,放置规则既可以代指绑定对象的放置策略 (placement policy),也可以代指 TiDB 发给 PD 的放置规则。

    该功能可以实现以下业务场景:

    • 合并多个不同业务的数据库,大幅减少数据库常规运维管理的成本
    • 增加重要数据的副本数,提高业务可用性和数据可靠性
    • 将最新数据存入 NVMe,历史数据存入 SSD,降低归档数据存储成本
    • 把热点数据的 leader 放到高性能的 TiKV 实例上
    • 将冷数据分离到不同的存储中以提高可用性
    • 支持物理隔离不同用户之间的计算资源,满足实例内部不同用户的隔离需求,以及不同混合负载 CPU、I/O、内存等资源隔离的需求

    指定放置规则,首先需要通过 CREATE PLACEMENT POLICY 语句创建放置策略 (placement policy)

    然后可以使用 或者 ALTER TABLE 将规则绑定至表或分区表,这样就在表或分区上指定了放置规则:

    1. CREATE TABLE t1 (a INT) PLACEMENT POLICY=myplacementpolicy;
    2. CREATE TABLE t2 (a INT);
    3. ALTER TABLE t2 PLACEMENT POLICY=myplacementpolicy;

    PLACEMENT POLICY 为全局作用域,不与任何数据库表结构相关联。因此,通过 CREATE TABLE 指定放置规则时,无需任何额外的权限。

    要修改放置策略,你可以使用 语句。修改将传播到所有绑定此放置策略的对象。

    1. ALTER PLACEMENT POLICY myplacementpolicy FOLLOWERS=5;

    要删除没有绑定任何分区或表的放置策略,你可以使用 DROP PLACEMENT POLICY

    1. DROP PLACEMENT POLICY myplacementpolicy;

    查看放置规则

    如果一张表绑定了放置规则,你可以用 SHOW CREATE TABLE 来查看。还可以用 来查看已经创建的放置策略。

    你也可以用 INFORMATION_SCHEMA.PLACEMENT_POLICIES 系统表查看所有放置策略的定义。

    1. tidb> select * from information_schema.placement_policies\G
    2. ***************************[ 1. row ]***************************
    3. POLICY_ID | 1
    4. CATALOG_NAME | def
    5. POLICY_NAME | p1
    6. REGIONS | us-east-1,us-west-1
    7. CONSTRAINTS |
    8. LEADER_CONSTRAINTS |
    9. FOLLOWER_CONSTRAINTS |
    10. LEARNER_CONSTRAINTS |
    11. SCHEDULE |
    12. FOLLOWERS | 4
    13. LEARNERS | 0
    14. 1 row in set
    1. SELECT * FROM information_schema.tables WHERE tidb_placement_policy_name IS NOT NULL;
    2. SELECT * FROM information_schema.partitions WHERE tidb_placement_policy_name IS NOT NULL;

    所有绑定规则的对象都是异步调度的。可以用 来查看放置规则的调度进度。

    Placement Rules in SQL - 图2

    注意

    • 放置选项依赖于正确地指定在每个 TiKV 节点配置中的标签 (label)。例如,PRIMARY_REGION 选项依赖 TiKV 中的 region 标签。若要查看当前 TiKV 集群中所有可用的标签,可执行 语句。

      1. mysql> show placement labels;
      2. +--------+----------------+
      3. | Key | Values |
      4. +--------+----------------+
      5. | disk | ["ssd"] |
      6. | region | ["us-east-1"] |
      7. | zone | ["us-east-1a"] |
      8. +--------+----------------+
      9. 3 rows in set (0.00 sec)
    • 使用 CREATE PLACEMENT POLICY 创建放置规则时,TiDB 不会检查标签是否存在,而是在绑定表的时候进行检查。

    除以上配置选项外,你还可以使用高级配置,详细介绍见高级放置选项

    示例

    配置项的默认值为 3。如要为特定的表调大该值,可使用配置策略,示例如下:

    注意,PD 配置中包含了 leader 数和 follower 数。因此,5 个副本为 4 个 follower + 1 个 leader。

    对于以上示例,你还可使用 PRIMARY_REGIONREGIONS 选项来描述 follower 的放置规则:

    1. CREATE PLACEMENT POLICY eastandwest PRIMARY_REGION="us-east-1" REGIONS="us-east-1,us-east-2,us-west-1" SCHEDULE="MAJORITY_IN_PRIMARY" FOLLOWERS=4;
    2. CREATE TABLE t1 (a INT) PLACEMENT POLICY=eastandwest;

    SCHEDULE 选项指示 TiDB 如何平衡 follower。该选项默认的 EVEN 调度规则确保 follower 在所有区域内分布平衡。

    如要保证在主区域内 (us-east-1) 放置足够多的 follower 副本,你可以使用 MAJORITY_IN_PRIMARY 调度规则来使该区域的 follower 达到指定数量。该调度牺牲一些可用性来换取更低的事务延迟。如果主区域宕机,MAJORITY_IN_PRIMARY 无法提供自动故障转移。

    1. CREATE PLACEMENT POLICY p1 FOLLOWERS=5;
    2. CREATE PLACEMENT POLICY europe PRIMARY_REGION="eu-central-1" REGIONS="eu-central-1,eu-west-1";
    3. SET tidb_enable_list_partition = 1;
    4. CREATE TABLE t1 (
    5. country VARCHAR(10) NOT NULL,
    6. userdata VARCHAR(100) NOT NULL
    7. ) PLACEMENT POLICY=p1 PARTITION BY LIST COLUMNS (country) (
    8. PARTITION pEurope VALUES IN ('DE', 'FR', 'GB') PLACEMENT POLICY=europe,
    9. PARTITION pNorthAmerica VALUES IN ('US', 'CA', 'MX') PLACEMENT POLICY=northamerica,
    10. PARTITION pAsia VALUES IN ('CN', 'KR', 'JP')
    11. );

    如果分区没有绑定任何放置策略,分区将尝试继承表上可能存在的策略。比如,pEurope 分区将会应用 europe 策略,而 pAsia 分区将会应用表 t1 的放置策略 p1。如果 t1 没有绑定任何策略,pAsia 就不会应用任何策略。

    给分区绑定放置策略后,你可以更改指定分区的放置策略。示例如下:

    1. ALTER TABLE t1 PARTITION pEurope PLACEMENT POLICY=p1;

    你可以为某个数据库指定默认的放置策略,类似于为数据库设置默认字符集或排序规则。如果没有指定其他选项,就会使用数据库上指定的配置。示例如下:

    注意分区与表之间的继承和这里的继承不同。改变表的放置策略,也会让分区应用新的策略。但是只有建表时没有指定放置策略的时候,表才会从数据库继承放置策略,且之后再改变数据库也不影响已经继承的表。

    放置选项 PRIMARY_REGIONREGIONSSCHEDULE 可满足数据放置的基本需求,但会缺乏一些灵活性。在较复杂的场景下,若需要更灵活地放置数据,可以使用高级放置选项 CONSTRAINTSFOLLOWER_CONSTRAINTS。、REGIONSSCHEDULE 选项不可与 CONSTRAINTS 选项同时指定,否则会报错。

    以下示例设置了一个约束,要求数据必须位于某个 TiKV 节点,且该节点的 disk 标签必须匹配特定的值:

    1. CREATE PLACEMENT POLICY storageonnvme CONSTRAINTS="[+disk=nvme]";
    2. CREATE PLACEMENT POLICY storageonssd CONSTRAINTS="[+disk=ssd]";
    3. CREATE PLACEMENT POLICY companystandardpolicy CONSTRAINTS="";
    4. CREATE TABLE t1 (id INT, name VARCHAR(50), purchased DATE)
    5. PLACEMENT POLICY=companystandardpolicy
    6. PARTITION BY RANGE( YEAR(purchased) ) (
    7. PARTITION p0 VALUES LESS THAN (2000) PLACEMENT POLICY=storageonssd,
    8. PARTITION p1 VALUES LESS THAN (2005),
    9. PARTITION p2 VALUES LESS THAN (2010),
    10. PARTITION p3 VALUES LESS THAN (2015),
    11. PARTITION p4 VALUES LESS THAN MAXVALUE PLACEMENT POLICY=storageonnvme
    12. );

    该约束可通过列表格式 ([+disk=ssd]) 或字典格式 ({+disk=ssd: 1,+disk=nvme: 2}) 指定。

    在列表格式中,约束以键值对列表格式。键以 +- 开头。+disk=nvme 表示 disk 标签必须设为 nvme-disk=nvme 表示 disk 标签值不能为 nvme

    在字典格式中,约束还指定了适用于该规则的多个实例。例如,FOLLOWER_CONSTRAINTS="{+region=us-east-1: 1,+region=us-east-2: 1,+region=us-west-1: 1}"; 表示 1 个 follower 位于 us-east-1,1 个 follower 位于 us-east-2,1 个 follower 位于 us-west-1。再例如,FOLLOWER_CONSTRAINTS='{"+region=us-east-1,+disk=nvme": 1,"+region=us-west-1": 1}'; 表示 1 个 follower 位于 us-east-1 区域中有 nvme 硬盘的机器上,1 个 follower 位于 us-west-1

    注意

    使用限制

    目前已知 Placement Rules in SQL 特性存在以下限制:

    • 临时表不支持放置规则。
    • 设置 PRIMARY_REGIONREGIONS 时允许存在语法糖。但在未来版本中,我们计划为 PRIMARY_RACKPRIMARY_ZONEPRIMARY_HOST 添加变体支持,见 。