本文分享自华为云社区《华为云GES:十年磨一剑,打造业界一流的云原生分布式图数据库》,作者:GES图引擎服务小图 。

1、浅谈云原生图数据库

图数据库(graph database)是一个使用图结构进行语义查询的数据库,它使用节点、边和属性来表示和存储数据。该系统的关键概念是图,它直接将存储中的数据项,与数据节点和节点间表示关系的边的集合相关联。这些关系允许直接将存储区中的数据连接在一起,并且在许多情况下,可以通过一个操作进行检索。

图数据库强调数据之间的关系。查询图数据库中的关系很快,因为它们永久存储在数据库本身中。可以使用图数据库直观地显示关系,使其对于高度互联的数据非常有用。因此图数据库广泛应用在互联网、知识图谱、金融风控等需要挖掘深度关联关系的场景。

“到2023年,图技术将促进全球30%企业的快速决策场景化。需要图还是不需要?这已不再是个问题,一定是需要”,Gartner公司副总裁、杰出分析师Mark Beyer讲到。

云原生图数据库从名字看是从云原生和图数据库概念发展而来的。而云原生的概念通用意义上可以理解为应用以服务化或云化的方式提供给用户。此类云原生图数据库是在云基础架构之上进行构建的,图数据库组件在云基础设施之上构建、部署和分发。这种云原生属性是它相比于其他类型图数据库最大的特点。作为一种云平台,云原生图数据库以 SaaS(软件即服务,Software-as-a-Service)的形式进行分发。

2、云原生数据库与其他图数据库解决方案有什么不同?

从上图的图数据库VS图数据库on云服务器VS云原生图数据库的对比图我们可以看到:云原生图数据库因为具有即开即用、稳定可靠、管理便捷、弹性伸缩等优点,可以帮助用户减少图数据库总拥有成本(TCO)和运维工作量(O&M),用户可以将主要精力聚焦在核心业务上。

3、华为云GES:为什么受到客户的广泛认可?

华为云图引擎服务(GES)是一种基于华为云基础架构和平台的在线数据处理图数据库,提供即开即用、可扩展且完全托管的分析型图数据库服务。作为拥有自主知识产权的分布式原生图数据库和图引擎产品,提供一站式的图存储、图查询和图计算能力,支持业界标准图查询语言cypher和gremlin,同时支持30+高性能算法,覆盖多场景分析计算,具备10+图神经网络和图嵌入算法。广泛应用于互联网、政务、安平、税务、电力等行业,为客户的辅助决策、降本增效等提供专业、高效的服务。

从2013年预研到2015年GES内核Eywa研发内部立项再到现在,整十年的发展过程中,华为云GES始终保持高强度研发投入,已经硕果累累。GES同时提供与HCS8.X、HCSO配套的混合云版本。从2017年底华为云正式公测,到目前上线华为云国内站10+站点,海外新加坡、俄罗斯、阿联酋、爱尔兰、南非等站点,马电、法电等合营云站点,服务海内外几十家客户,目前呈现多点开花的局面,显示出GES强大的产品竞争力。

十年磨一剑,GES作为国内最早发布的云原生分布式图数据库,“云原生”优势主要体现在如下几个方面:

  • 完全托管

GES是完全托管的在线图数据库服务,后台会为每个最终租户创建与之对应的资源租户,部署GES需要的计算、存储、网络等资源,均通过资源租户发放,用户只需通过GES提供的Portal界面或者API访问图数据库即可,无需关注图数据后台的底层资源。GES提供了7*24小时oncall,如果这些资源发生故障(比如所在的物理机故障),oncall会立即感知到并处理,整个过程用户无需操作,用户省心又安心。

针对部分用户希望感知到图数据库后台资源(比如CPU、内存、磁盘等)以及图数据库关键指标(响应时间、容量占用等)的诉求,GES针对每个图实例也对接了华为云的CES服务,用户可以在CES界面查看到GES的监控指标,并对关注的指标配置告警,一旦监控值超过阈值,可以及时通知到用户。

  • 资源动态扩展

GES提供了在线对图实例进行扩容、扩副本的能力,实现资源动态扩展。

扩容操作一般发生在容量不足的场景,比如初始阶段申请了一亿规格的图实例,后期随着业务的增长需要扩容到十亿规格,可以简单通过界面点击完成,整个扩容过程业务不中断且支持从小规格一次性扩容到任意的大规格。

扩副本操作一般发生在并发性能有更高要求的场景,比如初始阶段申请了一亿规格的图实例,默认GES是提供一主一从两个副本部署方式,后期随着业务的增长对QPS有了更高的要求,可以扩容成一主多从多个副本。扩副本整个过程可以简单通过界面点击完成,整个扩副本过程中业务不中断,且支持一次性扩容多个副本。

  • 版本在线升级

GES图实例的版本支持在线升级,用户只需要在界面点击即可升级到最新版本,新版本可能是新需求上线、漏洞修复(包括开源软件或者操作系统)、Bug修复等。升级过程由用户触发且不收取任何费用。

GES当前版本发布周期在1个月左右,也就是说用户的新需求最快可以1个月之内上线。GES新版本上线后,用户通过升级即可满足新需求。借助华为云内部强大的版本发布系统,针对严重阻塞用户的问题,GES能够做到24小时修复。比如2021年Log4J爆出的“核弹级”漏洞,GES在24小时之内完成了新版本上线,上线后用户快速升级即可完成漏洞修复。

  • 容灾和数据高可靠

GES实例采用一主多从架构,主从切换业务不感知,使用多副本机制保障高可用。支持跨AZ容灾,单机房故障不丢数据、不中断业务,RTO秒级。

图实例支持手工备份和自动备份两种备份方式。手工备份用户可以在界面点击触发,一般用作重大变更(比如升级或者数据清空)前生成一个数据快照,如果变更问题可以及时将数据会退到该快照。自动备份是图数据库内部的行为,为数据可靠性服务。如果服务器发生宕机,GES后台会通过自动备份和写日志,快速进行数据恢复,确保数据不丢失。

GES实例支持跨AZ部署,用户只需要在发放图实例时勾选上启用跨AZ即可,无需额外费用。主从集群数据跨机房存放,实现单机房故障不丢数据。业务计算资源跨机房调度,单机房故障不中断业务。且在正常情况下,计算和数据在数据中心内部交互,减少机房间带宽消耗。

  • KMS数据加密

如上面所讲,GES是完全托管的服务,用户的备份数据是存储到资源租户的OBS桶上面,针对部分用户数据密级较高的场景,GES提供了基于KMS服务的数据加密方案。

GES加密存储的客户数据包括两种:

1、客户原始数据:支持创建的元数据文件存储到OBS上时加密。

2、导入到图系统里面的数据:

(1)String类型的属性会存储到云硬盘EVS,支持对EVS加密。

(2)增量备份、全量备份会备份到OBS/HDFS,支持对增量备份和全量备份的加密。

GES提供了基于KMS服务的数据加密方案,如下图所示:

站在管理面视角:

❶租户管理员登录华为公有云后,在GES Console上申请创建加密实例;

❷ GES Service接收到创建加密实例请求后,向KMS Service申请主密钥和集群密钥,并生成数据库密钥下发给GES内核;

❸ GES业务实例在初始化时加载密钥,并加密保存。

站在数据面视角:

❹客户导入点、边数据集、Schema文件,支持这些数据存储在OBS时使用KMS加密;

❺ 若用户创建图备份,则在内存数据加密后生成备份数据并存储到OBS;若用户从备份恢复图,则从OBS下载备份数据,然后解密后加载到内存。

  • 安全性

GES提供多个特性来保障租户图实例的可靠性和安全性,例如VPC、安全组、权限设置、SSL连接、手动/自动备份等,如下图所示:

    • 网络隔离:VPC 允许租户通过配置 VPC 入站 IP 范围来控制连接图实例的 IP 地址段。GES实例运行在租户独立的 VPC 内。租户可以创建一个跨可用区的子网组,之后可以根据业务需要,将部署 GES的实例选择此子网完成,GES 在创建完实例后会为租户分配此子网的 IP 地址,用于连接GES实例。GES 实例部署在租户 VPC 后,租户可通过 VPN 使其它 VPC 能够访问实例所在 VPC,也可以在 VPC 内部创建 ECS,通过私有 IP 连接GES实例。租户可以综合运用子网和安全组的配置,来完成GES实例的隔离,提升实例的安全性。
    • 认证鉴权:GES实例任何操作,都需要进行IAM认证鉴权。
    • 访问控制:租户可以为不同的用户组分配不同的GES权限,包括GES Administrator、GES Super User、GES Operator权限。GES Administrator拥有GES的最高权限,可以对GES资源进行任意操作;GES Super User拥有除创建和删除GES实例以外的所有操作权限,包括GES实例的启动/停止、导入/导出,GES实例的访问等操作;GES Operator拥有GES实例的访问操作,无法进行GES实例的资源类操作。
    • 存储加密:GES支持读取加密存储到OBS的数据,加密密钥由 KMS 管理。
    • 备份与恢复:GES 提供自动/手动两种备份方法,执行备份后会对整个GES实例进行全量备份,这些备份数据存储在华为 OBS 桶中,当用户删除实例时,会同步删除 OBS 桶中的备份。用户也可以从已有的备份恢复到实例。
    • 数据安全:用户删除 GES 实例时,存储在GES实例中的数据都会被删除,任何人都无法查看及恢复数据。
    • 主机安全:GES基于华为云内部欧拉操作系统,做了多种加固,定期更新操作系统最新补丁。采用图实例升级的方式,用户可以及时修复OS漏洞。
  • 细粒度权限控制:

在企业生产里面,权限控制尤为重要。例如,在公司里面,HR部门才能看到绩效、级别等信息;财务部门才肯看到账号、转账等信息;而其他信息公开,公司内所有员工都可以看到。

GES图实例提供了界面化的细粒度权限控制,可对特定Label的特定属性设置遍历(traverse)、读、写权限。适用于企业对不同部门的权限设置,并对用户组进行授权,权限模型如下图所示:

  • 过载控制

过载,是服务或应用处理的请求超过了自身所能承载的能力,造成服务或应用自身处理请求时延变慢、错误率增加,或者请求失败,乃至服务中断。GES图实例内部集成了过载控制组件,提供了流控、降级、熔断等机制帮助业务实现过载保护。

GES按需地为每个图实例预置了系统CPU、系统内存、应用JVM内存、应用连接数、应用任务阻塞数等5种过载指标,确保整个系统不会被恶意或者无意的瞬时高并发容量冲垮。而且一旦发生过载,GES还可以根据用户诉求设置降级策略,确保这一异常情况下用户的核心业务核心API不受影响。

  • 支持HCS、HCSO、华为云多种形态

针对不同客户对云形态的要求,GES提供 HCS、HCSO、华为云等多种云形态的版本,配套HCS8.X和HCSO 23.3.0、23.9.0等版本,方便用户选择不同场景下的云服务。

点击关注,第一时间了解华为云新鲜技术~

十年磨一剑的华为云GES,高明在哪的更多相关文章

  1. ZT:阿里合伙人发文:十年磨一剑,自研数据库终拿世界第一

    按:真正做技术的,就该这样. 以下为全文转载 (观察者网讯) 10月24日,阿里巴巴合伙人.高德总裁刘振飞在阿里云开发者社区发文,回忆从2009年启动“去IOE”工程到2019年OceanBase拿下 ...

  2. 十年磨一剑 Delphi再写传奇(不争辩,不解释,十年坚持不懈的努力)

    新年伊始,英巴卡迪诺公司(Embarcadero)就在其官网发布了“激动人心的RAD Studio2018年发展规划”公告(见上图).公告中指出,将在于2018年发布10.3.X新版本,新版本兼容Ex ...

  3. 十年磨一剑,王坚自研的MaxCompute如何解决世界级算力难题

    摘要: 2009年这项关于大数据的技术长征开始.王坚带队,目标是自研大数据计算平台MaxCompute统一阿里巴巴内部的数据和大数据计算体系. 大数据时代,随着企业数据规模的急剧增长,传统软件已无法承 ...

  4. Seeing AI:计算机视觉十年磨一剑,打造盲人的“瑞士军刀”

    Mary Bellard(左)和AnneTaylor(右)是Seeing AI开发团队的成员,SeeingAI成果的背后是计算机视觉数十年研究的支持. 当Anne Taylor走进一个房间时,她像其 ...

  5. 十年磨一剑 Delphi重新崛起再写传奇

    新年伊始,英巴卡迪诺公司(Embarcadero)就在其官网发布了"激动人心的RAD Studio2018年发展规划"公告(见上图).公告中指出,将在于2018年第一季度发布10. ...

  6. Peter Norvig:自学编程,十年磨一剑

    若要在某一领域内达到专家级的水平,其关键在于"审慎地重复",也就是说,并非是机械地,一遍又一遍地练习,而是要不断地挑战自我,试图超越自身当前的水平,通过不断的尝试挑战,并在尝试的过 ...

  7. 华为云ModelArts图深度学习,学习知识还能考取微认证

    作为人工智能最前沿的技术之一,图深度学习被公认是人工智能认识世界实现因果推理的关键,也是深度学习未来发展的方向.但深度学习对图数据模型的支持性差一直是众多研究者难以攻克的难点,因此图深度学习在实际生产 ...

  8. 解密华为云FusionInsight MRS新特性:一架构三湖

    摘要:华为云安全网关产品总监郭冕在"华为云TechWave云原生2.0专题日"上发表<华为云FusionInsight MRS,一个架构实现三种数据湖>的主题演讲,分享 ...

  9. 华为云MVP:来自工业制造领域的微服务与云平台实践

    [摘要] 首先,和大家先聊聊的是为什么微服务.DevOps和云计算会在各个产业大行其道;其次,再谈谈微服务架构设计有那些自己独特的设计思想,和传统的SOA有什么区别;最后,我们再一起看一看在工业领域云 ...

  10. 大型情感剧集Selenium:6_selenium中的免密登陆与cookie操作 #华为云·寻找黑马程序员#

    欢迎添加华为云小助手微信(微信号:HWCloud002 或 HWCloud003),输入关键字"加群",加入华为云线上技术讨论群:输入关键字"最新活动",获取华 ...

随机推荐

  1. 2021-11-30:给定一个数组arr,当拿走某个数a的时候,其他所有的数都+a, 请返回最终所有数都拿走的最大分数。 比如: [2,3,1], 当拿走3时,获得3分,数组变成[5,4]; 当拿走5

    2021-11-30:给定一个数组arr,当拿走某个数a的时候,其他所有的数都+a, 请返回最终所有数都拿走的最大分数. 比如: [2,3,1], 当拿走3时,获得3分,数组变成[5,4]: 当拿走5 ...

  2. [ABC270F] Transportation

    [ABC270F] Transportation 题意 有 \(n\) 个点,有 \(m\) 条可以加上的边,如果两个点同时建立了一种东西,那么也算连了一条边,每条边都有个代价,每个点建一个东西也有不 ...

  3. 最通俗易懂的flex讲解

    30分钟彻底弄懂flex布局 欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由elson发表于云+社区专栏 目前在不考虑IE以及低端安卓机(4.3-)的兼容下,已经可以放心使用fle ...

  4. 在EXCEL和WPS表格里实现邮件合并功能

    在EXCEL和WPS表格里实现邮件合并功能 2020/3/21 22:06:09 0人评论 10635次 OFFICE邮件合并:在Office中,先建立两个文档:一个WORD包括所有文件共有内容的主文 ...

  5. 从源码角度剖析 golang 如何fork一个进程

    从源码角度剖析 golang 如何fork一个进程 创建一个新进程分为两个步骤,一个是fork系统调用,一个是execve 系统调用,fork调用会复用父进程的堆栈,而execve直接覆盖当前进程的堆 ...

  6. logging 模块因权限问题写入日志失败

    哈喽大家好,我是咸鱼 今天跟大家分享一个使用 Python 的 logging 模块写入日志文件时遇到的权限问题,不知道你们有没有遇到过 1.案例现象 今天上班的时候手机短信收到了 zabbix 告警 ...

  7. substrate 编译出错unresolved import `sp_runtime::testing` failed to resolve: could not find `GenesisConfig` in `system`

    error[E0432]: unresolved import `sp_runtime::testing` --> /Users/suyinrong/bitcoin-proj/substrate ...

  8. MySQL锁表解锁表

    CREATE TABLE t1 ( id int(11) NOT NULL, val varchar(10) DEFAULT NULL, PRIMARY KEY (id) ) ENGINE=InnoD ...

  9. React后台管理系统 03全局样式scss

    安装scss样式依赖,使用命令 npm i --save-dev sass  --dev 会将依赖安装在devDependencies=>开发环境的依赖. 我们在src目录下的assets下创建 ...

  10. Ryu控制器教程

    RYU不要使用apt的方法安装,这样的安装是不完整的, 并且相关文件不易查找. 1.下载ryu源码 cd cd Desktop git clone https://gitee.com/lpm-123/ ...