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的本地路由表。

相关推荐
好记忆不如烂笔头abc6 天前
查看oceanbase的license信息
oceanbase
隔壁老登14 天前
解决dbeaver连接不上oceanbase数据库的问题
数据库·oceanbase
❀͜͡傀儡师14 天前
Docker 安装部署 OceanBase
docker·容器·oceanbase
❀͜͡傀儡师15 天前
Kubernetes (K8s) 部署资源的完整配置OceanBase
容器·kubernetes·oceanbase
OceanBase数据库官方博客16 天前
当过滤条件不符合最左前缀时,如何有效利用索引? | OceanBase SQL 优化实践
sql·性能优化·oceanbase·分布式数据库
OceanBase数据库官方博客17 天前
如何利用 rowid 在OceanBase 中处理大表时提效
oceanbase·分布式数据库·性能调优·实践经验
赵渝强老师17 天前
【赵渝强老师】OceanBase租户的资源管理
数据库·mysql·oracle·oceanbase
GottdesKrieges22 天前
obd运维OceanBase数据库的常见场景
运维·数据库·oceanbase
OceanBase数据库官方博客23 天前
伯俊科技× OB Cloud:零售业落地AI的“三步走”渐进式发展实践
人工智能·oceanbase·分布式数据库
颜挺锐24 天前
在 OceanBase 中,使用 TO_CHAR 函数 直接转换日期格式,简洁高效的解决方案
数据库·oceanbase