澳门wap网站制作/做网站的公司哪家好

澳门wap网站制作,做网站的公司哪家好,免费又好用的wordpress模板,.net 创建网站项目背景 此篇博客的源自于OceanBase社区论坛内一位名为皇甫侯的热心用户所提的建议,希望向OceanBase的用户介绍OceanBase的版本升级路径。本文以一个版本升级为示例,汇总了对用户而言比较重要的版本升级要点,期望通过这份分享,能让读…

背景

此篇博客的源自于OceanBase社区论坛内一位名为皇甫侯的热心用户所提的建议,希望向OceanBase的用户介绍OceanBase的版本升级路径。本文以一个版本升级为示例,汇总了对用户而言比较重要的版本升级要点,期望通过这份分享,能让读者在阅读之后有所收获。

1725533698

OceanBase的产品版本号

在介绍升级路径之前,先简单介绍一下 OceanBase 的产品版本号,产品版本号代表 observer 的版本,每次发版时都会推高版本号:

  • 版本号的第一位代表架构的级别,修改架构才会推第一位版本号,目前(2024.09.05)最新版本是 4。
  • 版本号的第二/三位,代表新增了不同级别的大 feature。
  • 版本号第四位,则是代表每个分支版本下,定期对一批 bugfix 进行集中打包后发布的 BP (Bundle Patch) 版本。

这里需要注意的是,在前三位相同的情况下,第四位越大则代表当前版本推出越晚。前三位不同的情况下,无法通过产品版本号比较获得产品推出时间,因此一些 bugfix 是否存在需要根据产品拓扑图决定。

在每一位版本号后面还可能会有后缀,例如 CE、LTS、HF 等:

  • CE(Community Edition)代表社区版。
  • LTS(Long-Term Support)代表长期支持版,会在这个版本,长期解决稳定性 bug。
  • HF(HotFix)表示只增加了关键 bugfix 的版本,旨在解决个别 “走投无路” 难以绕过的问题。
  • GA(General Availability)代表稳定版本,是生产环境(即正式使用环境)下安全可靠的,可以广泛部署和用于日常业务操作的版本。在官网上可以看到 4.3.1 就是一个 GA 版本。

例如下图中 4.2.1_BP8(LTS) 就表示是 4.2.1 这个版本中进行过 8 次 Bundle Patch 的长期支持版本。

1725533711

Barrier 版本

我下载了一个 4.2.3.1 的 observer,想测试下通过 OCP 把很久很久之前部署的一个单机的 4.1.0.1 给升级到 4.2.3.1 版本(测试集群是单机单副本,所以没法儿轮转升级,只能停服升级)。

1725533721

本以为吃着火锅唱着歌就能把级给升了,结果不巧,OCP 说还需要给它上传一个额外的 barrier 版本。也就是说,需要下载两个 observer 的 binary 提供给 OCP,一个是需要经停的 4.2.1.2,一个是终点站 4.2.3.1。

1725533730

提供完了 barrier 版本的包就不用管了,OCP 会帮你把集群直接升级到最终的 4.2.3.1 版本。

1725533740

正好也趁这个机会,在介绍升级拓扑之前,先说一下什么是 barrier 版本,以及 barrier 版本的作用。

因为 OceanBase 在很多版本之间,都支持不停机地轮转升级,也就是各个低版本的 observer 会轮流替换成高版本,只要保持多数派还在就可以持续对外提供服务。所以在集群升级过程中,高版本的 observer 需要以低版本的模式持续运行一段时间,直到所有低版本的 observer 全部被替换成高版本为止。因此高版本需要继续保留低版本上的老代码。也就是说,即使低版本的功能在高版本上被废弃了,为了支持不停机升级,高版本的 observer 中也需要保留被废弃掉的古老代码。

为了减少维护版本之间升级兼容性的开销,避免让一个超级古老的版本直接升级到当前最新版本,带来大量的兼容代码维护负担。OceanBase 引入了一个 barrier 版本的概念。barrier 版本指的是某个低版本升级到某个高版本过程中,必须要经停的版本。在此 barrier 版本之前的版本,必须要先升级到 barrier 版本,才能继续升级到后续版本。这样研发同学在代码中,就不必考虑最新版本和上一个 barrier 版本之前的各种兼容性问题了。

如果大家觉得上面这两段介绍 barrier 作用的文字实在难以理解,也没有关系。只要看懂下面两张图,能够了解什么是 barrier 版本,基本也就够用了。

下图中有五个版本 A、B、C、D、E,其中 C 是 barrier 版本。对于 A、B 来说,都可以直接升级到 C。对于版本 C 来说,可以直接升级到 D 或 E。但是 A、B 无法直接升级到 D、E,他们升级到 D、E 的路径上,都需要经停版本 C,即先升级到版本 C,再升级到 D、E。

1725533749

另外一个需要注意的点是 barrier 是针对某个版本的,即这个 barrier 可能对一些版本是 barrier,升级必须经停,对另一些则不是 barrier。

下图中有四个版本 A、B、C、D,其中 C 对于 A 来说是 barrier版本,那么如果 A 要升级到 D,就必须要经停 C,无法直接升级到 D,整个升级流程是 A -> C -> D。而 C 对于 B 来说不是 barrier 版本,所以 B 可以直接升级到 D。

1725533756

这里需要注意的是,上面写的 “经停” 并不代表需要停机升级,只是比喻升级过程需要经历先升级到 barrier 版本,再升级到目标版本的这样一个过程。

升级拓扑

经停了 barrier 版本这一部分内容之后,终于来到了升级拓扑。定义升级拓扑图的文件叫 oceanbase_upgrade_dep.yml,感兴趣的朋友,可以点开前面的链接看看 github 中的对应文件,文件里有不少有价值的中文注释供大家参考。

这个文件会放在安装目录里,不同版本的内容略有不同,因为发现编译安装和通过 OCP 安装的文件路径好像还不太一样,所以就请大家自行 find 下吧。

1725533771

1725533779

升级拓扑主要由以下部分组成:

  • version: 待升级的版本,或者升级过程中经过的版本。
  • can_be_upgraded_to:当前版本可以直接升级到的版本号。
  • deprecated:缺省为 False。如果为 True,表示这个版本已经废除。可以作为升级的起点,可以作为升级过度版本,但是不建议作为升级目标版本。
  • require_from_binary:缺省为 False。如果为 True,表示是上面提到的 barrier 版本。
  • when_come_from:一般是一个列表,伴随 require_from_binary 出现,表示从列表中的版本升级时,需要经停当前版本。

1725533798

上图是一个升级的例子,为方便大家理解做了一些简化,不代表某个真实版本升级拓扑(不同版本的真实升级拓扑详见安装路径中的 oceanbase_upgrade_dep.yml 文件,一般可能会比上图略微复杂一些)。

图中左边有四个版本,分别是 4000、4001、4100、4200(这里偷懒省去数字之间的点号),其中 4100 是一个 barrier 版本,when_come_from: [4.0.0.0] 表示当低版本是从 4000 升级过来时,需要经停 4100。

但是因为 when_come_from 列表中没有 4001,所以 4001 可以直接升级到 4200,不需要经停 4100。这里再次强调下 barrier 版本是相对于某个版本而言的,例如这里的 4100 相对于 4000 是 barrier 版本,但是相对于 4001 则不是 barrier 版本。

大家可以这么理解:整个升级文件构成了一张类似于上图中右侧的有向无环图,整个升级流程就完全展示在这张升级拓扑图上。除非某个 barrier 版本指定说从某个特定的起始版本升级上来就需要经停它这个版本,否则就可以继续在这个图上往后不经停,直接升级到目标版本。(这段话稍微有一点儿绕,大家结合上面这个例子理解下~)

升级流程和升级脚本

因为这部分内容过于开发者向,考虑到这篇博客的读者可能绝大多数都是 OceanBase 的使用者或 DBA 同学,为了不浪费大家的宝贵阅读时间,这里暂时就先略去不讲了,哈哈~

实话实说,这部分内容虽然我略知一二,但非内核开发同学完全没必要了解,并非故意不讲,望大家谅解。这里先留一个坑位也不是吊大家胃口,而是日后如果真的有开发者提出诉求,方便我直接在这里动笔补上相关内容。

What Else

最后在这里给社区论坛中新增的 “官方精选” 板块 做一个介绍。“官方精选” 是汇聚了由)OceanBase 团队精心挑选或创作的内容。包括但不限于:

  • 产品公告:OceanBase 内核及平台工具发布的新特性,以及产品的重要更新;
  • 问题精粹:取之于论坛的优质问题、排查过程和结论,并会增加相关的技术解析;
  • 互动精华:在论坛帖子中发现的有趣的问题和相应的分析,以及从用户贡献的内容中精选出的具有代表性的讨论或解决方案;
  • 实践指南:通过不同行业和不同场景的最佳实践,分享经过验证的架构案例和配置建议;
  • 其他:与生态上下游的联合解决方案等等。

如果大家在社区论坛中,写出或者看到优质的帖子,可以随时 @ 兹拉坦 进行投稿,如果内容被官方精选板块选中,会有相应的积分奖励。如果大家对官方精选板块有任何建议,也可以随时 @ 兹拉坦 进行吐槽,我们会改到令大家满意为止~ 


OceanBase 云数据库现已支持免费试用,现在申请,体验分布式数据库带来全新体验吧 ~

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

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

相关文章

Docker Desktop 安装与使用详解

目录 1. 前言2. Docker Desktop 安装2.1 下载及安装2.2 登录 Docker 账号2.3 进入 Docker Desktop 主界面 3. Docker 版本查看与环境检查3.1 查看 Docker Desktop 支持的 Docker 和 Kubernetes 版本3.2 检查 Docker 版本 4. Docker Hub 和常用镜像管理方式4.1 使用 Docker Hub4…

推理大模型的后训练增强技术-Reasoning模型也进化到2.0了,这次居然学会用工具了

论文题目:START: Self-taught Reasoner with Tools 论文链接:https://arxiv.org/pdf/2503.04625 论文简介 Reasoning模型也进化到2.0了,这次居然学会用工具了!✨ 最近有个叫START的方法,让大模型也能学着用工具&#…

基于llama.cpp的QwQ32B模型推理

基于llama.cpp的QwQ32B模型推理 llama.cpp项目主页: https://github.com/ggml-org/llama.cpp# llama.cpp源码下载 cd /root/lanyun-tmpgit clone https://github.com/ggml-org/llama.cpp#llama.cpp编译 llama.cpp是个C语言项目,实际调用过程需要先构建项…

如何使用Spring AI提示词模板PromptTemplate?

如何使用Spring AI提示词模板PromptTemplate 目录 如何使用Spring AI提示词模板PromptTemplate 1、提示词Prompt介绍 2、Spring Boot集成Spring AI框架 3、提示词模板PromptTemplate用法 4、开发代码使用PromptTemplate 5、启动Springboot工程并验证 本文章节介绍Prompt…

Windows Server中的NTP服务器部署(NTP Srver Deployment in Windows Server)

构建稳定内网时间同步:Windows Server中的NTP服务器部署指南 服务简介 NTP(Network Time Protocol)服务器是用于同步计算机网络中各设备时间的服务器。它通过网络协议与标准时间源(如原子钟、GPS系统等)进行时间同步&…

【 <二> 丹方改良:Spring 时代的 JavaWeb】之 Spring Boot 的自动配置:约定优于配置的设计美学

<前文回顾> 点击此处查看 合集 https://blog.csdn.net/foyodesigner/category_12907601.html?fromshareblogcolumn&sharetypeblogcolumn&sharerId12907601&sharereferPC&sharesourceFoyoDesigner&sharefromfrom_link <今日更新> 一、Spring…

SourceTree的安装与使用

SourceTree的安装与使用 一、前言 作为可视化Git管理工具&#xff0c;SourceTree可以避免我们使用命令进行常规的代码拉取&#xff0c;更新&#xff0c;合并等操作。 鼠标点点就可以完成代码管理的工作。所以强烈推荐可视化的工具。不过SourceTree还是有点bug&#xff0c;比…

JMeter 性能测试

Jmeter 用户手册 名词解释&#xff1a; RPS&#xff1a;每秒请求数-每秒向服务器发送多少请求数&#xff08;一个场景&#xff0c;系统面临多大的压力&#xff09; TPS&#xff1a;每秒事务数-每秒能够处理多少请求/事务数性能评价标准&#xff08;其中的一个核心指标&#x…

【Mac 从 0 到 1 保姆级配置教程 09】09. 快速配置终端复用工具 tmux 和 oh-my-tmux

文章目录 1. 前言2. 安装 tmux3. 配置 tmux4. 安装 oh-my-tmux5. 最后6. 参考资料7. 系列教程 Mac 从 0 到 1 保姆级配置教程目录&#xff0c;点击即可跳转对应文章&#xff1a; 【Mac 从 0 到 1 保姆级配置教程 00】 - 教程说明 【Mac 从 0 到 1 保姆级配置教程 01】 - 安装无…

Java 大视界 -- 基于 Java 的大数据机器学习模型的迁移学习应用与实践(129)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

通义万相 2.1 与蓝耘智算平台的深度协同,挖掘 AIGC 无限潜力并释放巨大未来价值

我的个人主页 我的专栏&#xff1a; 人工智能领域、java-数据结构、Javase、C语言&#xff0c;希望能帮助到大家&#xff01;&#xff01;&#xff01; 点赞&#x1f44d;收藏❤ 引言&#xff1a;AIGC 浪潮下的新机遇 在当今数字化飞速发展的时代&#xff0c;人工智能生成内容&…

C语言高级学习之变量和内存分布

一.变量和内存分布 1.课程要求 2.技术层次 3.C语言标准 1.3.1 K&R C 起初&#xff0c;C语言没有官方标准。1978年由美国电话电报公司(AT&T&#xff09;贝尔实验室正式发表了C语言。布莱恩柯林汉&#xff08;Brian Kernighan&#xff09; 和 丹尼斯里奇&#xff08;D…

蓝桥杯学习-12递归

12递归 1.概述 2.几个递归模板 (1)求阶乘 int f(int n){ if(n 1) return 1; return f(n-1) * n; }(2)斐波拉契序列 int f(int n){ if(n 1 || n 2) return n; return f(n - 1) f(n - 2); }例题一-蓝桥5194 int f(int n){if(n 0) return 1;if(n % 2 0) return f(n / 2)…

Python----数据可视化(Pyecharts三:绘图二:涟漪散点图,K线图,漏斗图,雷达图,词云图,地图,柱状图折线图组合,时间线轮廓图)

1、涟漪特效散点图 from pyecharts.globals import SymbolType from pyecharts.charts import EffectScatter from pyecharts.faker import Faker from pyecharts import options as opts from pyecharts.globals import ThemeType # 绘制图表 es (EffectScatter(init_optsop…

自然语言处理预训练模型的研究综述

&#x1f4d5;参考&#xff1a;&#xff1a;2020-11-02,https://kns.cnki.net/kcms/detail/11.2127.tp.20201030.1952.017.html 主要是这篇文章的自己摘了点笔记。 预训练模型的深度学目标是如何使预训练好的模型处于良好的初始状态&#xff0c;在下游任务中达到更好的性能表现…

一次Linux下 .net 调试经历

背景&#xff1a; Xt160Api, 之前在windows下用.net调用&#xff0c;没有任何问题。 但是移植到Linux去后&#xff0c;.net程序 调用 init(config_path) 总是报错 /root/test 找不到 traderApi.ini (/root/test 是程序目录) 然后退出程序 解决过程: 于是考虑是不是参数传错了&…

iOS底层原理系列01-iOS系统架构概览-从硬件到应用层

1. 系统层级结构 iOS系统架构采用分层设计模式&#xff0c;自底向上可分为五个主要层级&#xff0c;每层都有其特定的功能职责和技术组件。这种层级化结构不仅使系统更加模块化&#xff0c;同时也提供了清晰的技术抽象和隔离机制。 1.1 Darwin层&#xff1a;XNU内核、BSD、驱动…

日志存储与分析

日志是系统运行的详细记录&#xff0c;包含各种事件发生的主体、时间、位置、内容等关键信息。出于运维可观测、网络安全监控及业务分析等多重需求&#xff0c;企业通常需要将分散的日志采集起来&#xff0c;进行集中存储、查询和分析&#xff0c;以进一步从日志数据里挖掘出有…

Flutter 边框按钮:OutlinedButton 完全手册与设计最佳实践

目录 1. 引言 2. OutlinedButton 的基本用法 3. 主要属性 3.1 核心属性详解 3.2 ButtonStyle 子属性详解 (styleFrom/copyWith) 状态响应优先级说明 4. 自定义按钮样式 4.1 修改边框颜色和文本颜色 4.2 修改按钮形状 4.3 修改按钮大小 4.4 集中演示 5. 结论 相关推…

【Node.js入门笔记4---fs 目录操作】

Node.js入门笔记4 Node.js---fs 目录操作一、目录操作1.fs.mkdir()&#xff1a;创建目录。异步&#xff0c;非阻塞。创建单个目录创建多个目录创建目前之前需要确认是否存在&#xff1a; 2. fs.mkdirSync()&#xff1a;用于创建一个新的目录。异步&#xff0c;非阻塞。3.fs.rmd…