【OceanBase 的多租户架构是怎样的?有什么优势?】

作为"DBA面试君",在聊 OceanBase (OB) 的时候,"多租户(Multi-tenancy)" 是你必须拿捏住的核心卖点。在传统数据库(如 MySQL/Oracle)中,多租户通常是通过多个实例或逻辑 Schema 实现的,资源隔离很差。而 OceanBase 在内核层面实现了一套类似"云操作系统"的资源管理机制。

Part 1

OceanBase 多租户架构:数据库里的"虚拟机"

OceanBase 的多租户架构可以类比为"集装箱"或"Docker 容器"。在一个 OB 集群中,资源被划分为多个独立的物理池。

01 资源单元 (Unit)

Unit 是资源分配的最小颗粒。它规定了 CPU、内存、磁盘 IO 和连接数 的具体规格。

  • 物理隔离: 每一个 Unit 在 OBServer 进程内都有独立的 Cgroup(用于 CPU 隔离)和独立的内存块。

02 资源池 (Resource Pool)

一组 Unit 的集合。一个资源池只能属于一个租户。

03 租户 (Tenant)

租户是业务使用的最高单位。

  • 逻辑独立: 每个租户拥有独立的系统表、Schema 和用户权限。

  • 完全对等: 租户之间像虚拟机一样互不感知,租户 A 的慢 SQL 不会直接导致租户 B 的内存溢出(OOM)。

Part 2

多租户架构的核心优势

在面试中,你要从"降本"和"增效"两个维度来回答:

01 极致的资源利用率 (Consolidation)

  • 长尾业务整合: 过去你可能有 100 个小业务,需要开 100 个 MySQL 实例,资源浪费极其严重。现在只需一个 OB 集群,为每个业务开一个极小规格的租户,显著降低服务器成本。

  • 超卖与错峰: OB 支持 CPU 的超卖(Over-subscription),能像云主机一样利用不同业务的峰谷差异,压榨硬件性能。

02 严格的资源隔离

  • 抗干扰: 某个租户出现"大查询"或"全表扫描"时,资源被严格限制在其 Unit 内,不会抢占同一台物理机上其他租户的 CPU 和内存资源。

03 极速弹性伸缩 (Scale-out/in)

  • 动态扩容: 如果租户 A 业务量暴增,你可以直接通过一条 SQL 修改其 Unit 规格(如从 4核 16G 改为 16核 64G),秒级生效,业务无感知。

  • 跨节点迁移: OB 可以自动将某个租户的 Unit 从一台压力大的 OBServer 迁移到另一台空闲的 OBServer,整个过程数据不断流。

04 管理成本降低

  • 一套集群,万种业务: DBA 只需要维护一套集群的备份、升级和监控,而不需要管理成百上千个散乱的单机实例。

Part 03

DBA面试君的"进阶话术"

面试官提问: "OceanBase 的多租户和 Oracle 的 PDB(可插拔数据库)有什么区别?"

专业回答:

"Oracle PDB 虽然实现了逻辑隔离,但在底层 IO 和 CPU 调度上的硬隔离做得不够彻底,并且还是单机的架构。OceanBase 是原生分布式设计基于Sharding Nothing的架构,它的多租户是基于自研的资源调度器和 LSM-Tree 存储引擎,不仅能隔离CPU、内存,还能实现不同租户在Clog的物理配额管理以及IOPS的隔离,是真正的'租户即实例'。"

Part 04

说这么多理论,我们来点租户创建相关的实操加印印象

1 .在 OCP 服务器上,使用 obclient 客户端工具连接 OceanBase 集群。

2 .创建资源配置 u1 和 u2 如下所示。

3 .使用资源配置 u1 创建资源池 rp1,报 4733 错误:CPU resource not enough。

4 .使用资源配置 u2 创建资源池 rp1,报 4733 错误:MEMORY resource not enough。

5.使用系统视图 GV$OB_SERVERS,查看 observer 可供分配的 CPU、内余额是多少。

6 .鉴于 observer 可分配 CPU、内存小于资源配置 u1、u2 的需要,使用更小的资源配置 u3 来创建资源池。

7.使用资源池 rp1 创建租户 tenant1。

8 .创建租户 tenant2。

9 .查看集群内各个 observer 上租户的资源分配情况。

  1. 使用系统视图 GV$OB_SERVERS,再次查看 observer 可供分配的 CPU、内余额是多少。

11查看不同租户的 clog、data 盘以及 cgroup 的隔离情况。

1)在/data/1 目录下查看不同租户间 sstable 数据文件的隔离情况。

2) 在/data/log1 目录下查看各个租户间 clog 日志的隔离情况。

3)在/sys/fs/cgroup/cpu/oceanbase 目录下查看各个租户间 clog 日志的隔离情况。

相关推荐
顶点多余2 小时前
使用C/C++语言链接Mysql详解
数据库·c++·mysql
xiaokangzhe2 小时前
MySQL 数据库操作
数据库·oracle
发际线还在3 小时前
互联网大厂Java三轮面试全流程实战问答与解析
java·数据库·分布式·面试·并发·系统设计·大厂
小王不爱笑1324 小时前
MyBatis 执行流程源码级深度解析:从 Mapper 接口到 SQL 执行的全链路逻辑
数据库·sql·mybatis
山峰哥4 小时前
SQL优化实战:从索引策略到执行计划的极致突破
数据库·sql·性能优化·编辑器·深度优先
总要冲动一次5 小时前
离线安装 percona-xtrabackup-24
linux·数据库·mysql·centos
lcrml5 小时前
nacos2.3.0 接入pgsql或其他数据库
数据库
阿达_优阅达5 小时前
告别手工对账:xSuite 如何帮助 SAP 企业实现财务全流程自动化?
服务器·数据库·人工智能·自动化·sap·企业数字化转型·xsuite
IvorySQL5 小时前
IvorySQL v5 发布后,我们想听听大家的使用体验
数据库·postgresql·开源