QCon 演讲火热征集中,快来分享技术实践与洞见! 了解详情
写点什么

透视华为云云原生数据库的前世今生及未来演进,能给行业带来哪些启发?

  • 2023-01-11
    北京
  • 本文字数:4726 字

    阅读完需:约 16 分钟

透视华为云云原生数据库的前世今生及未来演进,能给行业带来哪些启发?

自云计算出现后,风云变幻十余载,硬件、软件行业都经历了重构变革所带来的机遇与激荡。企业 IT 基础设施逐渐云化,应用转向云端,系统架构也经历了从单体到微服务再到 Serverless 架构的演进。这些变化一方面为用户提供了更优秀的特性,另一方面也对云计算的组件提出更高要求。大势的裹挟之下,数据库作为云计算关键技术和最基础的服务之一,同样需要不断进化以适应日新月异的场景需求。自此,通过云服务形式提供数据库功能的云数据库应运而生,但这还仅仅是数据库变革的开端。

云数据库进一步演进:云原生数据库诞生


相比传统数据库,云数据库确有一定的进步,但是其本质上并非针对云场景或云环境来设计和构建的,只是用到了云的资源,因此存在一些局限,比如资源利用率低、维护成本高、可用性低等,从而限制了业务发展。随着云计算深入发展,云计算步入云原生时代。同时,越来越多企业加速数字化转型,业务对数据的诉求不断提升,倒逼着云数据库进一步演进,更加适应云特性的云原生数据库就此诞生。云原生数据库的目标主要是充分利用云基础设施的资源弹性调度实现数据库资源的极致弹性伸缩、数据就近访问、多模兼容,让用户专注在业务创新,而不用在数据库管理和运维层面耗费资源。云原生数据库的这些优势,受到越来越多企业的欢迎,而且热度不断攀升,已经成为数据库行业的重要发展趋势之一。

云原生数据库缘何兴起


为什么云原生数据库这么火?在华为云数据库软件总工程师彭立勋看来,第一,传统数据库的使用门槛相对较高。以前,数据库主要是本地部署(On-Premises),从采购机器、规划容量到部署软件,整个过程非常复杂。他说:“有了云计算,尤其是云原生数据库出现后,正好遇上企业数字化转型,对数据库的需求增加,而云原生数据库可以开箱即用,不用像以前那样做大量规划、采购和部署等。”


第二,云原生数据库能满足企业对数据库弹性伸缩的需求。而传统的做法是靠 DBA 规划,这很容易出现问题。对此,彭立勋深有感触,他以前做 DBA 时,要对容量做很精细的规划。如果规划没做对的话,要么浪费资源,要么性能不足,然后还要重新调整。


第三,云原生数据库可以从技术上解决传统数据库面临的资源、性能和扩展性受限等问题。传统上,这些问题要靠 DBA 不断提升自己的技术能力去解决。他表示,云原生数据库出现后,云服务商提供的相应产品本身就具备这样的能力,因此对企业来说,数据库的使用门槛大大降低。所以,在进行数字化转型时,很多企业倾向于选择云原生数据库。从传统数据库到云原生数据库,这是数据库自身的演进。更重要的是,数据库演进的背后折射出企业业务的变化。


据彭立勋介绍,首先,从以资源为中心到以应用为中心。从企业视角出发,它一定有一些自身需求,比如要求资源能弹性扩展。以前,缺乏这种技术时,企业主要是以资源为中心,有多少资源配多少数据库,然后再根据资源的表现和负载情况进行调整。云原生数据库出现后,从以资源为中心转变成以应用为中心,通过技术手段让用户使用更简单。企业只管用数据库,不用管背后到底需要多少资源。如果资源不够,系统自动帮你扩展,或者用户手动进行弹性扩展,速度更快、效率更高。并且,企业无需像以前那样预先规划资源,直接自动或手动调整资源即可。


其次,从以地域为中心到以流量为中心。以前,数据在哪,应用就要布置在哪,或者说应用在哪,数据也要同步到哪,这是以地域为中心。为了给用户提供最快访问,企业往往需要在各地设置数据中心,然后通过各种方法把数据同步到用户就近访问的地方。基于云原生数据库,企业只需要关注流量从哪里来,用户从哪里访问,数据库会将数据分布到不同的 Region,应用就近、随时随地访问数据。彭立勋表示:“应用在哪,数据库帮你把数据往哪同步。对用户来说,全球是一张网。”


最后,从以负载为中心到以数据为中心。传统上,不同的负载要放在不同的数据库里,比如报表、分析类的会放在一种数据库里,文档或键值类的放在另一种数据库。云原生数据库出现后,用户不同的负载由云服务商在后端适配不同的数据库实例,或者帮用户做同步,将数据放到适合做相应查询的数据库里。不管用户使用什么类型的负载和数据模型,都由云服务商帮用户判断。


“比如偏 OLAP 的,我们把它转到适合 OLAP 的数据查询的节点上。简单说,华为云云原生数据库改变了用户习惯,让用户对数据库的使用变得没有那么复杂。”他补充道。


此外是商业模式的改变。传统数据库是基于授权来获取商业收入,企业在使用数据库前要先购买 license。如果预估不准,企业采购的 license 就会存在浪费或不足的情况。而云原生数据库是以云服务的方式提供给用户,按需使用,用多少资源、使用多长时间,相应的为使用资源付费。

云原生数据库命中企业痛点,最大挑战不在技术


基于长期的行业观察,彭立勋总结出云原生数据库的价值。首先,云原生数据库开箱即用,使用简单,用户只要购买云原生数据库的服务,就可以直接使用。同时,按需使用,需要多少资源,用户就购买多少资源,一旦资源不够,还能快速扩容。这大大降低了企业使用数据库的门槛,减少企业在数据库部署等基础运维和管理上的人力投入。


其次,对数据库人员来说,不用关注最底层的运维问题,可以更靠近业务,关注数据处理等更有价值的问题。如此,不仅可以提升数据库人员的能力,而且能给企业带来更大的价值。


然后,云服务商将整个技术打包成服务,提供给所有用户,这让一些中小企业能像大企业一样使用相同的云原生数据库服务,享受技术带来的红利。此外,云原生数据库可以让企业应用系统更高效快捷地处理数据,充分发挥数据的价值。彭立勋解释道,“以前,中小企业可能没有那么多资源部署数据挖掘和分析。而现在采用 华为云云原生数据库后,它提供 HTAP 混合负载的能力。这样,中小企业也可以做一些轻量级的数据分析,挖掘数据中的价值,让企业更专注在业务创新上。”


目前,虽然云原生数据库很火,但是企业在采用过程中依然存在挑战。在彭立勋看来,很多企业从传统的商业数据库向云原生数据库迁移时,最大的挑战倒不是技术本身,而是很多的技术人员还是从传统数据库的角度出发,利用传统数据库的思维和积累的经验,来使用云原生数据库。


他强调,云原生数据库并非简单地把传统数据库搬到云上,它对数据库进行了全面重构,充分利用了云的能力,带来一些新优势。所以,如果还是按照传统数据库的使用习惯和思维模式,将无法发挥云原生数据库的优势,甚至可能会增加其使用成本。当然,对企业而言,是否采用云原生数据库,它需要根据具体业务进行判断。


从业务角度看,云原生数据库更适合偏互联网型的业务,诸如电商、社交、文娱、游戏、车联网等。偏互联网型的业务非常敏感,变化快,业务体量的弹性非常大。以游戏为例,一款游戏在突然火爆后,游戏公司需要在短时间内弹性扩展整个系统处理能力。而一款游戏进入收缩期后,需要快速收缩资源、节省成本。这类变化非常快的业务会对数据库的性能、弹性伸缩、快速部署等提出很高的要求,这恰恰是云原生数据库的优势所在。无论是什么样的企业,只要是偏这种类型的业务,都非常适合使用云原生数据库。

云原生数据库未来将如何发展


从星星之火到燎原之势,在数据库领域,云原生数据库蔚然成风,风起云涌之后的云原生数据库又将怎样演进、驶向何方?


在华为云看来,“以客户为中心,解决客户最关注的问题”是接下来云原生数据库发展演进的关键。基于此,华为云提出云原生数据库的三大发展方向:Serverless、Regionless 和 Modeless,这也成为 华为云云原生数据库 的发展指南


彭立勋说:“客户最关注的几个问题,一是资源调度,二是数据访问,三是使用体验。现在,越来越多的客户希望聚焦业务,聚焦于挖掘数据的价值,而非聚焦做一个具体的技术,因为对大部分有这种业务的企业来说,它并非一家做 IT 技术的企业,它关注的是自己所在领域的业务。所以,针对这几个方面,我们提出 Serverless、Regionless 和 Modeless 三大发展方向。”


具体说来,Serverless 要解决资源调度问题,实现资源的极致弹性。在遭遇故障、规格变更时,整个资源弹性调度速度可以从分钟级缩短到秒级,这样对用户来说,真正的无感知;Regionless 是解决用户的数据访问,数据库全域可用,业务可以在任意地方进行接入和访问,同时带来跨地域的高可用,用户只需关注业务的数据流动而不用担心业务的跨地域部署和访问;Modeless 要解决的是使用体验,一个统一入口能智能地处理各种类型的负载,不管是交易型、分析型、 NoSQL 模型、 MySQL 模型,我们以统一入口,提供给用户,提升用户的易用性和效率。


当然,Serverless、Regionless 和 Modeless 的落地应用还需要更具体的技术支撑。Serverless 方向,华为云云原生数据库在三个能力上重点投入,分别是 ALT、AST、ATC。首先是通过 ALT 应用无损透明倒换框架(Application Lossless and Transparent)实现应用层对底层调度倒换的无感知,当用户进行主备切换、小版本升级或者规格变更时,系统可以打包用户的会话上下文状态,在达到安全的事务边界后,确保会话上下文状态被完整重放至目标节点并与原会话一一关联保证业务持续性,不受各种操作的影响。


其次是通过 AST 应用弹性透明调度框架(Application Scaling Transparent)满足根据负载智能调度实例的需求,AST 融合了一些 AI 的能力,能够根据客户负载情况生成模型预测,从而以更精确的方式,提前扩缩资源。


最后是通过 ATC 应用透明集群(Application Transparent Cluster)实现读写能力的横向透明扩展。


Regionless 方向,华为云云原生数据库会重点聚焦于全域分层式引擎、全域数据总线(Global Dataflow Bus )和全域一致性集群三个方面。彭立勋认为, Regionless 首先要实现的便是低成本跨越存储,不同的数据中心的存储成本是不一样的,从成本角度考虑,最合理的方式就是将客户不常用的或者对时间不敏感的资源,放到一些比较低成本的地域, 华为云云原生数据库的全域分层式引擎就是为了实现这个诉求;同时,要为所有的数据提供就近访问、跨域访问的数据分布,还需要有一个全域的数据总线(Global Dataflow Bus),它能让用户在不同的 Region 之间按需复制数据,接下来还将根据数据的访问频次更加智能地判断、精细化调度;此外,面向数据全球化的场景,华为云云原生数据库也在投入全域一致性集群方面的研发,利用类似全球转发的技术,去实现用户不管从全球哪里接入,所看到的数据都是一致的。


彭立勋称:“最终我们要达到的目的是通过 Regionless 实现全球数据多活、故障自动再倒换、本地数据就近访问、全域数据分层的低成本存储。”


Modeless 方向,一方面华为云云原生数据库充分利用软硬件结合的优势,去高效处理不同类型的查询,比如数据并行查询 NDPQ 技术;另一方面推出了 HTAP 混合负载查询能力,它能够为用户同时提供一个一致性的行存和列存,给用户提供两种数据模型,通过优化器的智能调度,就能判断用户到底是适合哪一种数据模型,然后再从相应的数据引擎中把数据抽出来,实现快速访问;除此之外,针对多种模型混合的业务,华为云云原生数据库正在规划多模一体化的模型处理与转换总线,最终实现一个接口满足所有模型。

写在最后


毫无疑问,云原生数据库逐渐成为数据库行业的“宠儿”。它的流行代表着云原生发展的深化,更反映出数字化转型背景下,企业对数据库的诉求和态度。技术的巨轮滚滚向前,条条大路的尽头,终归是用户的需求,核心都是帮助用户优先解决业务问题,从而走上业务发展的快车道。作为国内云原生数据库的代表之一,华为云云原生数据库的实践和探索正是基于华为云多年来对用户需求洞察的结果而展开的,如何真正做到以客户为中心,解决客户最关注的问题,是华为云数据库求索的方向,也是值得全行业去思考的话题,由此,将可能再一次迸发出改变世界的力量。

2023-01-11 15:214152

评论

发布
暂无评论
发现更多内容

Docker镜像超详细介绍

Java 程序员 后端

Elasticsearch Document Index API详解、原理与示例

Java 程序员 后端

ELK太重?试试KFC日志采集

Java 程序员 后端

Elasticsearch查询速度为什么这么快?看啥?问你呢!

Java 程序员 后端

Eureka(F版本)教程三 服务消费者(Feign)

Java 程序员 后端

Flink on Yarn三部曲之三:提交Flink任务

Java 程序员 后端

Flink的sink实战之一:初探

Java 程序员 后端

Flutter中的widget

Java 程序员 后端

disruptor笔记之一:快速入门

Java 程序员 后端

Elasticsearch中的Term查询和全文查询

Java 程序员 后端

elasticsearch实战三部曲之二:文档操作

Java 程序员 后端

PS基础操作-新建画布和打开图片

hepingfly

ps教程 ps学习笔记

Docker多阶段构建实战(multi-stage builds)(1)

Java 程序员 后端

Docker系列(2)--容器和镜像的使用

Java 程序员 后端

Elasticsearch聚合学习之四:结果排序(1)

Java 程序员 后端

ConcurrentHashMap锁的前世今生,了解一下

Java 程序员 后端

Docker多阶段构建实战(multi-stage builds)

Java 程序员 后端

dubbo实战之三:使用Zookeeper注册中心

Java 程序员 后端

Elasticsearch Mapping parameters(主要参数一览)

Java 程序员 后端

elasticsearch的字符串动态映射

Java 程序员 后端

Filter 过滤器和 Listener 监听器

Java 程序员 后端

CPU战争40年,终于把Intel打趴下了

Java 程序员 后端

Docker下Nacos持久化配置

Java 程序员 后端

ELK性能优化实战总结:我强任我强,你“跪”标准好好学

Java 程序员 后端

Flink数据源拆解分析(WikipediaEditsSource)

Java 程序员 后端

Docker下的Nacos环境开发

Java 程序员 后端

架构实战营 - 模块三作业

危险游戏

架构实战营

Dubbo overrideDirectoryUrl的作用?

Java 程序员 后端

Elasticsearch文档读写模型实现原理

Java 程序员 后端

Elasticsearch聚合学习之四:结果排序

Java 程序员 后端

Eureka(F版本)教程五 路由网关(zuul)

Java 程序员 后端

透视华为云云原生数据库的前世今生及未来演进,能给行业带来哪些启发?_语言 & 开发_万佳_InfoQ精选文章