OceanBase 的ODP OBproxy 的记录

                                       OceanBase 的ODP的路由说明

一、简述为什么使用ODP的原因

(强一致性情况下)

1.分布式数据库在SQL解析这块存在本地执行计划,远程执行计划,分布式执行计划。

本地执行计划:整个SQL的表都在session所在的Observer 节点上。

远程执行计划:整个SQL的表都不在session所在的Observer 节点上,但是全部分布在另外一个Observer节点上。

分布式计划:分区主副本存在跨多个Observer节点的情况,会触发数据的重分布,然后再进行SQL部分的jion计算。

2.本地,远程,分布式的情况说明

本地执行计划:可以说ODP多了一条网络连接耗时。

远程执行计划:存在Observer1将SQL解析后,将PLAN传给Observer2的情况,存在网络开销(PLAN>SQL)。并且会将结果传给Observer1,在反馈给ODP,最终反馈给客户。

如果Observer1直接将SQL传给Observer2,会进行硬解析。

分布式执行计划:对SQL进行解析,然后产生大量的数据重分布问题,然后再进行SQL部分的jion运算,并进行合并,导致占用大量的时间。

二、ODP的作用

前言:ODP 可以进行轻量级别的SQL解析,并根据本地的路由缓存进行SQL链路,减少远程执行计划,分布式执行计划的网络方面的消耗。

ODP路由的功能与策略

OBproxy 会通过proxy@sys账户获取租户的信息,然后根据租户的信息,以及根据SQL的from语句部分与where条件部分进行对比,确定路由规则(LDC,Leader,读写分离等),获取本地缓存的路由表(如果过期,会在接触到Observer后,反馈给ODP,然后进行目标Observer寻址),然后进行黑白名单确认,确认后,转发SQL。 转发SQL成功后,新的Observer会更替ODP的本地路由表。

相关推荐
OceanBase数据库官方博客3 天前
半连接转内连接 | OceanBase SQL 查询改写
sql·oceanbase·分布式数据库
OceanBase数据库官方博客3 天前
解析在OceanBase创建分区的常见问题|OceanBase 用户问题精粹
oceanbase·分布式数据库·分区
OceanBase数据库官方博客3 天前
半连接转内连接规则的原理与代码解析 |OceanBase查询优化
sql·oceanbase·分布式数据库
IT培训中心-竺老师6 天前
OceanBase 数据库分布式与集中式 能力
数据库·分布式·oceanbase
靖顺6 天前
【OceanBase 诊断调优】—— OceanBase 数据库网络速率配置方案
网络·数据库·oceanbase
尚雷558014 天前
OceanBase 社区版 4.0 离线方式升级bp1至bp2 指南(含避坑总结)
oceanbase
五月高高14 天前
Linux部署oceanbase
linux·oceanbase
靖顺17 天前
【OceanBase 诊断调优】—— 统计信息自动收集超时导致的估行不准 SQL 选择错索引
数据库·sql·oceanbase
it界的哈士奇18 天前
Oceanbase离线集群部署
oceanbase