【赵渝强老师】OceanBase OBServer节点的接入层

在这里插入图片描述

OceanBase数据库代理ODP(OceanBase Database Proxy,又称OBProxy)是OceanBase数据库的接入层,负责将用户的请求转发到合适的OceanBase数据库实例上进行处理。ODP是独立的进程实例,独立于OceanBase数据库实例部署。ODP监听网络端口,兼容MySQL网络协议,支持使用MySQL驱动的应用直接连接OceanBase数据库。ODP能够自动发现OceanBase集群的租户及数据分布信息,对于代理的每一条SQL语句,能尽可能识别出该语句将要访问的数据,并将该语句直接转发到数据所在服务器的OceanBase数据库实例。


《OceanBase数据库课程:Oracle模式》

视频讲解如下

【赵渝强老师】OceanBase OBServer节点的接入层

客户端通过ODP访问OceanBase数据库的数据链路如下图所示。
在这里插入图片描述

作为OceanBase数据库的关键组件,ODP具有以下特性:

  • 连接管理

针对一个客户端的物理连接,ODP维持自身到后端多个OBServer节点的连接,并维持了每个OBServer节点连接的会话状态,保证了客户端高效访问各个OBServer节点。

  • 最佳路由

ODP充分考虑用户请求涉及的副本位置、用户配置的读写分离路由策略、OceanBase多地部署的最优链路,以及OceanBase各机器的状态及负载情况,将用户的请求路由到最佳的OBServer节点,最大程度地保证了OceanBase整体的高性能运转。

  • 高性能转发

ODP完整兼容MySQL协议,并支持OceanBase自研协议,采用多线程异步框架和透明流式转发的设计,保证了数据的高性能转发,同时确保了自身对机器资源的最小消耗。

  • 易运维

ODP本身无状态,支持无限水平扩展,支持同时访问多个OceanBase集群。可通过丰富的内部命令对ODP状态进行实时监控,这使得运维简单便利。

  • 高可用

ODP高可用分为两部分:一方面保证自身高可用,持续提供代理服务;另一方面ODP是OceanBase高可用体系的主要组成部分,可以对用户屏蔽宕机、升级等情况,保证OceanBase数据库服务的稳定和快速恢复 。

《OceanBase数据库课程:MySQ模式》

  • 专有协议

ODP与OBServer节点默认采用了OceanBase专有协议,如增加报文的CRC校验保证与OBServer节点链路的正确性,增强传输协议以支持Oracle兼容性的数据类型和交互模型。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/86804.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/86804.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

ISP Pipeline(8): Color Space Conversion 颜色空间转换

Color Space Conversion(颜色空间转换) 是图像处理中的一个重要步骤,它将图像从一个颜色空间(Color Space)转换到另一个,以满足 显示、分析、压缩或算法需求。 为什么转换颜色空间? 应用场景…

Spring Web MVC ①

🚀 一、Spring MVC MVC三层 Controller:乐团指挥,接收请求→调用模型→选择视图(Controller) Model:乐手,处理业务逻辑与数据(POJO对象) View:舞台展示&…

【数据挖掘】贝叶斯分类学习—NaiveBayes

NaiveBayes 朴素贝叶斯的核心是贝叶斯定理,它描述了如何根据新证据更新事件的概率。 要求: 1、实现朴素贝叶斯分类算法,验证算法的正确性,并将算法应用于给定的数据集Data_User_Modeling数据集,选择一部分数据集作为已…

Java面试宝典:基础二

🔒 25. final vs abstract 关键字 关键字修饰对象作用规则final类禁止被继承final class MyClass { ... }方法禁止被子类重写public final void func()变量变为常量(基本类型值不可变,引用类型地址不可变)final int MAX 100;abs…

小米手机安装charles证书

使用红米手机下载Charles证书一直下载中,无法正常下载。 不使用原装浏览器,使用第三方浏览器下载就可以了。 使用第三方浏览器安装,如我使用的是UC浏览器 使用第三方浏览器安装的证书格式是".pem"格式问卷 将这个文件放入小米的dow…

DeepSeek R2 推迟发布:因 H20 算力短缺

DeepSeek 今年早些时候凭借其 R1 AI 模型备受广泛关注。据《The Information》报道,R2 模型的工作似乎因 H20 处理器而停滞不前。 DeepSeek尚未透露其R2 模型的具体上市时间。 DeepSeek 使用 5 万块 Hopper GPU(包括 3 万块 H20、1 万块 H800 和 1 万块…

智能之火,重塑创造:大模型如何点燃新一代开发引擎?

导言:普罗米修斯之火再现 在科技演进的长河中,每一次生产力的跃迁都伴随着工具的质变。从蒸汽机轰鸣到电力普及,再到信息高速公路的铺就,人类驾驭能量的能力不断突破。今天,我们站在一个崭新的临界点上:大语…

一文入门JS

转自个人博客 因为本人经常使用QML,而由于QML与JS之间的关系,本人经常使用到JS相关语法,所以在此系统性对JS基础知识进行总结、记录。 1. 入门 JavaScript(简称 JS)是一种广泛应用于Web开发的脚本语言,它…

libtool: error: ‘/usr/.local/lib/libgmp.la‘ is not a valid libtool archive

背景: 安装gcc时提示需要vc11,然后安装gcc依赖gmp、mpfr、mpc。 到mpc make时出错: libtool: error: ‘/usr/.local/lib/libgmp.la’ is not a valid libtool archive 详细: /usr/bin/grep: /usr/.local/lib/libgmp.la: No such f…

HDC2025聚焦鸿蒙生态,FairGuard加固方案保驾护航

近日,在2025年华为开发者大会(HDC)上,华为正式启动HarmonyOS 6开发者Beta,并全面展示一年多以来与合作伙伴共建鸿蒙生态的创新成果:“累计有9000多个应用参与了70多个系统级创新体验的联合打造,目前有3万多鸿蒙应用和元…

GAN的思考及应用

一、对文献的思考 CycleGAN的思考,前两周看到了关于CycleGAN的原始论文,是用于处理图像数据,有了如下思考: 1、基础理论与方法 《Unpaired Image-to-Image Translation using Cycle-Consistent Adversarial Networks》是Cycle…

Xcode26新特性与iOS26适配指南

Xcode 26 新特性 在 WWDC25 上 Apple 推出了 Xcode 26,相比较 Xcode 16,它有如下的变化。 项目 安装包更小,其他组件与工具链只有在需要时才会下载。设置界面重新设计,菜单从顶部挪到了左侧,其中 Accounts 改名为 Apple Accounts,Text Editing 改名为 Editing,Key Bind…

闲庭信步使用SV搭建图像测试平台:第二十课——RGB图像转HSV图像

(本系列只需要modelsim即可完成数字图像的处理,每个工程都搭建了全自动化的仿真环境,只需要双击文件就可以完成整个的仿真,大大降低了初学者的门槛!!!!如需要该系列的工程文件请关注…

Django的CSRF保护机制

一、Django的CSRF保护机制 1. 核心原理 作用&#xff1a;防止跨站请求伪造&#xff08;CSRF&#xff09;攻击&#xff0c;确保表单提交来源可信。实现方式&#xff1a; 在模板中使用{% csrf_token %}生成一个隐藏的<input>字段&#xff08;如csrfmiddlewaretoken&#…

JavaScript中的回调函数详解

JavaScript中的回调函数详解 1.1 概念 1.1.1 什么是回调函数 **回调函数&#xff08;Callback Function&#xff09;**是你将一个函数的引用&#xff08;指针&#xff09;作为参数传递给另一个函数&#xff0c;在那个函数完成任务后调用回来执行你传递的函数。简单的来说就是…

Utils系列之内存池(Fixed size)

内存池核心介绍 废话不多说&#xff0c;show you code. 我实现了两套内存池&#xff0c;一个是固定大小的内存池&#xff0c;一个是多重不同大小的内存池。 Fixed size memory pool 设计思路&#xff1a; 我们一个个看&#xff0c;首先我们定义了一个chunk, chunk 里面包含…

ubuntu安装docker遇到权限问题

问题现象&#xff1a; 使用snap安装的docker&#xff0c;执行docker build命令构建景象时报错&#xff1a; [] Building 0.1s (1/1) FINISHED docker:default > [internal] load build definition from Dockerfile 0.0s > > transferring dockerfile: 2B 0.0s ERROR:…

在Linux系统中部署Java项目

1.在Linux中启动mysql的服务: systemctl start mysql可以采用以下代码查看状态: systemctl status mysql如下图展示绿色代表启动成功 2.之后进入mysql mysql -uroot -p输入自己的密码&#xff0c;这里的密码不会显示,直接输入即可 3.在DG中连接Linux的数据库 4.修改配置文件…

C++洛谷P1002 过河卒

题目 链接&#xff1a;https://www.luogu.com.cn/problem/P1002 解析 这道题适用于了解动态规划的同学。 变量初始化 初始化B点坐标&#xff08;n, m&#xff09;和马的坐标&#xff08;a, b&#xff09; 初始化方向数组和动态规划数组 long long dp[30][30]; int dx[8] …

BlogX项目Go-gin--根据IP获取地理位置

先定义一个函数来判断IP地址是否为内网&#xff0c;归为工具类 // utils/ip/enter.go package ipimport "net"func HasLocalIPAddr(ip string) bool {return HasLocalIP(net.ParseIP(ip)) }// HasLocalIP 检测 IP 地址是否是内网地址 // 通过直接对比ip段范围效率更…