【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 日志的隔离情况。

相关推荐
不愿透露姓名的大鹏1 天前
Oracle Undo空间爆满急救指南(含在线切换+更优方案+避坑指南)
linux·运维·数据库·oracle
做个文艺程序员1 天前
MySQL 主从延迟根因诊断法
数据库·mysql
计算机安禾1 天前
【数据结构与算法】第33篇:交换排序(二):快速排序
c语言·开发语言·数据结构·数据库·算法·矩阵·排序算法
l1t1 天前
测试clickhouse 26.3的新功能
数据库·clickhouse
Mike117.1 天前
GBase 8a 批处理任务里的事务提交粒度和回滚边界
数据库
小江的记录本1 天前
【JEECG Boot】 《JEECG Boot 数据字典使用教程》(完整版)
java·前端·数据库·spring boot·后端·spring·mybatis
yjb.gz1 天前
Oracle物化视图概述
数据库·oracle
fundoit1 天前
MySQL Workbench中的权限设置不生效
数据库·mysql
ZzzZZzzzZZZzzzz…1 天前
MySQL备份还原方法2----LVM
linux·运维·数据库·mysql·备份还原
i220818 Faiz Ul1 天前
教育资源共享平台|基于springboot + vue教育资源共享平台系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·教育资源共享平台