首页 > 其他分享 >GaussDB技术解读——GaussDB架构介绍之集群管理层(CM)关键技术方案

GaussDB技术解读——GaussDB架构介绍之集群管理层(CM)关键技术方案

时间:2024-11-25 15:58:36浏览次数:4  
标签:DN 关键技术 CM GaussDB Agent Server 故障 仲裁

GaussDB Kernel V5 集群管理层关键模块如下。

在这里插入图片描述

图4 集群管理层组件设计图

CM 组件提供了四种服务 CM Agent, CM Server, OM Monitor, cm_ctl,与各类实例服务组件(CN, DN, GTM 等)一起构成了整个数据库集群系统。

cm_ctl

通过命令行执行集群的启动、停止、状态查询、主备倒换、备机重建等功能

除启动和停止外,主要通过与 CM Server 的消息传递执行命令

可在任意节点执行并获取到相同的结果

OM Monitor

由系统定时任务拉起

负责 CM Agent 的运行状态监控

CM Agent

由 OM Monitor 拉起

负责拉起和停止所在节点的 CN, DN, GTM, CM Server(如果存在);监控实例状态并上报至 CM Server;执行 CM Server 下发的命令等

对应 cm_agent 二进制文件,所有节点常驻服务

CM Server

由 CM Agent 拉起,是整个集群管理组件的大脑

负责接收 cm_ctl 发送的命令并下发至 CM Agent;接收并处理 CM Agent 上报的实例状态,下发仲裁指令保证各类故障和异常场景下集群的可用性

对应 cm_server 二进制文件,常驻服务

CM与各类组件的主备数据同步、倒换、重建等机制高度融合,提供告警、重启、倒换、隔离等手段,赋予数据库实例故障恢复及自愈的高可用(HA)能力,保证数据的可靠性和完整性,最终实现集群对外的业务连续性。

集群管理仲裁关键技术

单节点故障在生产过程中,不可避免。CM 组件可根据探测到的状态进行仲裁,从而尽可能恢复集群可用性的过程。

以某个主 DN 故障为例,一次典型的仲裁流程包括:

① CM Agent 1探测DN主实例并发现故障

② CM Agent 1持续上报实例故障信息至CM Server

③ CM Server执行仲裁流程,选择DN备机升主

④ CM Server下发升主命令至CM Agent 2

⑤ CM Agent 2对实例执行升主操作

在这里插入图片描述

图5 集群管理仲裁过程

常见的故障类型包含磁盘故障、网络故障、下电故障、操作系统故障、其它故障(CPU故障)等。CM在选举过程中,遵从DN多数派。即,对于某一个DN分片来说,故障后的选主,需要得到大多数DN的投票,候选DN副本才可以被选中升主。仲裁规则主要依据两个原则:1) 任期(Term)大,且日志长的DN副本优先被选主 2) 同等条件下,静态主优先。

CM辅助不同组件故障情况下恢复过程

  1. CN 故障 (集中式部署时,无CM节点)

DDL 语句无法执行,DML 语句不受影响

通过将故障 CN 剔除,可保障 DDL 语句不受影响

仅支持集群内 CN 个数大于 3,且 1 个 CN 发生故障时剔除

  1. DN 故障

单点故障可自动恢复

主 DN 故障时,仲裁备 DN 升主继续提供服务

备 DN 故障时,主 DN 将日志和数据同步至从备,业务不受影响

  1. 主 GTM 故障

备 GTM 升主后继续提供服务

  1. 主 CM Server 故障

备 CM Server 接受多数派 CM Agent链接,升主后继续提供服务

异常检测

从业界经验来看,数据库实例可能处于故障、僵死、亚健康等状态。这些状态的出现概率逐级降低,但检测难度逐级增高。尤其是如何区分亚健康状态和系统繁忙状态,具有较大的挑战性。

CM 组件包含异常检测流程,可用于识别和处理网络不稳定、磁盘 IO 挂死、进程/线程僵死、进程频繁退出、实例状态时好时坏等场景,提高集群的稳定性和可用性。

以 DN 短链接检测为例,CM Agent 按照固定时间间隔与 DN 实例新建链接。如果与某个主 DN 链接失败或通过新链接无法执行 SQL 语句,则认为该 DN 发生 1 次 Hang 异常。如果多次出现异常,则会触发 Hang 检测机制,将该 DN 实例杀死并执行主备切换。目前常见的异常检测项有:

短链接建立

通过短链接执行 SQL 语句

IO 挂死

内存占用异常

基于Paxos协议复制实现DN副本自仲裁

GaussDB Kernel V5 采用基于Paxos协议主备副本复制协议,实现DN副本的自仲裁功能。关键技术方案如下图所示,其中DCF为GaussDB Kernel V5 基于Paxos协议的一致性复制组件。需包含日志复制、自仲裁选主等功能。
在这里插入图片描述

图6 DN自仲裁设计

关键技术方案要点:1)DN 副本自仲裁,缩短仲裁链路,减小RTO 2)采用Paxos一致性协议,保证DN副本间的一致性,避免备机由于日志分叉产生增量重建。

未来技术方案演进:1) DCF组件日志与数据库内核日志合一,减少对IO的占用。2) 采用Parallel Paxos协议或者多主的Paxos协议提升日志复制的吞吐量 3)通过RDMA/UB 网络优化主、备节点日志传输,提升日志复制性能。

https://carrier.huawei.com/cn/products/it-new/cloud/dws

标签:DN,关键技术,CM,GaussDB,Agent,Server,故障,仲裁
From: https://www.cnblogs.com/xiaoxu0211/p/18567672

相关文章

  • GaussDB技术解读——GaussDB架构介绍之全局事务管理层(GTM)关键技术方案
    GTM仅处理全局时间戳请求,64位CSN递增,几乎都是CPU++和消息收发操作。不是每次都写ETCD,而是采用定期持久化到ETCD里,每次写ETCD的CSN要加上一个backup_step(100w),一旦GTM故障,CSN从ETCD读取出来的值保证单调递增。当前GTM只完成CSN++,预估可以支持200M/s请求。GTM处理......
  • GaussDB技术解读——GaussDB架构介绍之数据持久化存取层(DataNode)关键技术方案
    数据持久化存取层(DataNode)关键技术方案Datanode节点主要负责数据的持久化和快速写入、读取。数据持久化采用物理日志wal,事务提交wal刷盘,对外提供逻辑日志功能,反解析物理日志为SQL逻辑日志。图1datanode数据持久化Astore:存储格式为追加写优化设计,其多版本元组采用新、老版......
  • GaussDB 24
    GaussDB介绍华为自主创新研发的分布式关系型数据库。该产品具备企业级复杂事务混合负载能力,同时支持分布式事务,同城跨AZ部署,数据0丢失,支持1000+的扩展能力,PB级海量存储。同时拥有云上高可用,高可靠,高安全,弹性伸缩,一键部署,快速备份恢复,监控告警等关键能力,能为企业提供功能全面,稳定......
  • GaussDB技术解读——GaussDB架构介绍之OM运维管理关键技术方案
    ​GaussDBKernelV5OM运维管理关键模块如下。OM运维主要功能有:安装升级节点替换扩容、缩容自动告警巡检备份恢复、容灾日志分析系统在华为云的部署模式下,OM相关组件部署示意图如下:图7华为云OM运维管理用户登录华为云Console,访问GaussDBKernelV5的管控页面,输入......
  • 【Unity游戏开发】Plastic SCM Beta版服务到期,将Plastic hub(Plastic SCM Beta版)云端
    目录工作概述项目迁移1.访问团结云平台MigrationPage2.迁移项目连接本地项目1.下载团结云开发app1.1从Hub下载1.2从网页下载2.连接本地项目2.1连接本地项目问题1:找不到本地数据库问题2:提示“当前文件夹已存在工作区”3.成功连接本地项目后更新3.1成功连接本地项目3.2更新项目4.......
  • HCIA-03 常用协议 ARP TCP UDP ICMP
    TCP/IP模型与OSI模型对比1.TCP/IP模型分为四层:应用层、传输层、网络层、数据链路层。2.OSI模型(开放系统互联模型)为七层:应用层、表示层、会话层、传输层、网络层、数据链路层、物理层。3.TCP/IP模型中的传输层对应OSI模型中的传输层和会话层,网络层对应OSI模型的网络层,数据链路层......
  • 在当前工作目录下,以管理员身份运行cmd(如何通过命令提升管理员权限?)
    思路一、听说cmder可以右键打开当前工作目录的命令窗口,不过我懒得安装验证了。思路二、我发现百度找到的教程都不真正满足我的需求,最后从一篇文章得到了启发。我整理了需求,提示AI生成bat脚本代码,代码微改后,在当前工作目录下,可以用管理员身份运行cmd。【前置知识】Windows环......
  • 【资金趋势指标】安全买点的组合选股和指标操盘关键技术解密,操盘训练营核心技术点
    如上图,指标想要运用到精妙之处,我们就需要找到组合优化效用最大化的位置操作,如上图组合指标,我们主图选择【翻倍密码系统】,副图选择【资金趋势双档】副图指标。在上图标记AB两个买点位置,有什么需要注意的关键信号呢?(1)主图来看波段行情和趋势行情,紫色K线处于波段和趋势多头行情......
  • 如何使用PbootCMS内容详情页标签调用相关信息
    常用标签{content:id}:文章编号{content:scode}:栏目编码{content:subscode}:副栏目编码{content:sortname}:栏目名称{content:subsortname}:副栏目名称{content:sortlink}:栏目链接{content:subsortlink}:副栏目链接{content:title}:文章标题{content:titlecolor}:文章标题颜色......
  • PbootCMS 修改邮件提醒标题
    PbootCMS修改邮件提醒标题文件修改:文件1:apps/admin/controller/system/ConfigController.php,大约在31行。文件2:apps/api/controller/CmsController.php,两处。文件3:apps/home/controller/CommentController.php,大约在94行。文件4:apps/home/controller/FormController.php,大......