在 OceanBase 数据库中,系统租户可以对普通租户进行管理。主备集群之间的系统租户是相互独立的,不会物理同步数据,但是备集群会感知主集群普通租户的变化,保证同步所有普通租户的数据。备集群从主集群的系统租户逻辑同步的租户管理操作包括创建租户、删除租户和重命名租户。

    备集群也支持独立进行部分的租户管理操作,当前支持在主备集群上独立运维的租户管理操作如下:

    • 管理租户的资源配置

    • 管理租户的资源池

    • 管理租户的 Locality 配置

    • 管理租户的 Primary Zone 配置

    此外,主备库配置下,主备集群均不支持物理恢复租户。

    在主集群上创建租户的流程如下:

    1. 创建租户资源池

    2. 执行创建租户的 DDL

    为了保证备集群上租户的正常创建,在主集群上创建租户前,需要注意以下事项:

    • 在主集群上创建租户 Unit 配置时,需要参考备集群的资源水位。

      默认备集群的 Unit 配置与主集群一致,如果备集群的可用资源不足,可能会导致后续在备集群上自动创建租户失败。建议主集群和备集群采用相同的租户资源配置,在主集群上创建 Unit 配置时应参考备集群的资源水位,保证备集群后续能成功创建资源池。

    • 如果主备需要采用不同的租户资源配置,可以在备集群上设置 Unit 配置模板。

      如果备集群的硬件资源配置确实比主集群低,并且希望主集群和备集群采用不同的租户资源配置,可以在备集群上提前创建 Unit 配置模板 ,或者修改模板定义,用于定制备集群上的租户资源配置。

      用户可以在备集群上创建、删除和修改 Unit 配置模板 standby_unit_config_template,但创建资源池时不可以直接使用该模板。

      创建、查看和删除 Unit 配置模板的示例如下:

      • 创建备集群的资源规格模板

      • 删除资源规格模板

    • 主集群的租户创建成功后,需要监控备集群上的租户是否创建成功。

      具体操作操作如下:

      1. 在主集群上,查询 V$OB_STANDBY_STATUS 视图的 列。

        如果显示 SYS SCHEMA NOT SYNC,则表示系统租户的 Schema 不同步,可能出现了备集群创建租户卡住的情况。

      2. 在备集群上,查看 V$OB_CLUSTER_STATS 视图,观察各个租户的 Schema 和用户数据的同步进度。

        其中, 为 1 表示系统租户,对比主集群和备集群的 REFRESHED_SCHEMA_VERSION,确认备集群系统租户的 DDL 的同步进度,如果落后于主集群,则说明可能出现备集群同步创建租户的 DDL 卡住的情况。

      关于备集群创建租户时卡住问题的排查,请参见 备集群创建租户时卡住的问题

    租户日常维护注意事项

    • 在主集群上调整租户的资源配置时,建议也手动调整备集群的租户资源配置。

      建议尽量保证主集群和备集群的资源配置相同。由于备集群不会自动同步租户资源配置修改操作,调整主集群的租户资源配置后,建议也手动调整备集群的租户资源配置。

    • 由于租户级配置项不会自动同步到备集群,当主集群设置了租户级配置项后,建议也手动设置备集群的配置项。