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

相关推荐
tiancaijiben11 分钟前
阿里云函数计算FC如何实现网站的定时任务与自动化
数据库·oracle·dba
xfhuangfu11 分钟前
Oracle 19c 多租户体系架构介绍
数据库·oracle·架构
java1234_小锋15 分钟前
请描述 Spring Boot 的启动流程,包括 SpringApplication 的初始化和 run 方法的核心步骤。
java·数据库·spring boot
qq_谁赞成_谁反对27 分钟前
甲方IT的成长之路--nginx实战--2604
服务器·数据库·nginx
云水一下34 分钟前
从零开始学 PHP 系列(六):MySQL 数据库与 PHP 交互——让数据真正“住”进服务器
数据库·mysql·php
fofantasy36 分钟前
NSK LH25FL 升级至 NH25EM 技术规格指南
服务器·网络·数据库·经验分享·规格说明书
炘爚38 分钟前
Linux——Redis
数据库·redis·缓存
Oo_行者_oO1 小时前
删库先别跑路,万一修复呢?MySQL 误删数据恢复可落地运维文档
数据库·面试
曾阿伦1 小时前
深入了解MongoDB 两地三中心架构
数据库·mongodb·架构