如何性能调优

OceanBase 的 SQL 执行计划与 Oracle/MySQL 有哪些不同?在性能调优时,通常可以关注哪些视图或指标?

2 个赞

OceanBase 的 SQL 执行计划与 Oracle 和 MySQL 存在一些显著差异,主要体现在分布式特性、执行计划类型以及调优工具的使用上。

  1. SQL 执行计划的差异
    ‌分布式执行计划‌:由于 OceanBase 是一个分布式数据库,其执行计划中会包含‌分布式执行计划‌(Remote Execution Plan),这是其独有的特性。当 SQL 需要访问其他节点的数据时,OceanBase 会发起远程 fetch 操作,这在 Oracle 或 MySQL 中通常不会出现。在执行计划中,可以通过 plan_type 区分:

plan_type=1:本地执行计划(性能最好)。
plan_type=2:远程执行计划。
plan_type=3:分布式执行计划。
这类计划在性能调优时需要特别关注,以减少跨节点访问带来的延迟。

‌执行计划结构与 Oracle 类似‌:OceanBase 的 SQL 执行设计参考了 Oracle 的设计,包括硬解析、软解析、执行计划缓存等机制。支持多种连接算法,如嵌套循环、哈希连接、归并连接等,也支持子查询和 SQL 改写等高级功能。

‌SQL 路由机制‌:由于 OceanBase 的数据分布于多个节点,SQL 执行时需要通过 OBProxy 或 F5 VIP 进行路由。如果 SQL 需要访问多个节点,系统会生成远程执行计划,这也是调优时需特别注意的部分。

  1. 性能调优关注的视图与指标
    在进行 OceanBase 性能调优时,可以借助以下视图和指标进行诊断:

‌SQL 审计视图 gv$sql_audit‌:该视图记录了所有 SQL 的执行信息,包括执行时间、等待时间、执行节点、执行计划类型、报错信息等。它可以帮助快速定位慢查询和执行异常的 SQL 语句。

‌执行计划查看‌:通过 EXPLAIN、EXPLAIN BASIC、EXPLAIN EXTENDED 命令可以查看 SQL 的执行计划。尤其在排查问题时,EXPLAIN EXTENDED 提供了更详细的执行信息。

‌性能基线与监控指标‌:定期记录性能基线,包括响应时间、QPS、TPS、CPU 使用率、内存占用、磁盘 I/O 等,有助于识别性能瓶颈。

‌SQL 执行计划缓存与 Outline 功能‌:OceanBase 支持 SQL 计划基线和 Outline 功能,可以在线干预执行计划,调整连接顺序、算法等。

通过这些工具和视图,可以系统化地进行性能诊断与优化,尤其在分布式环境下,SQL 路由与远程执行计划是调优的关键点。

1 个赞

学习了,很到位

学习了,