任何应用系统都离不开对数据的处理,数据也是驱动业务创新以及向智能化发展最核心的东西。这也是为何目前大多数企业都在构建数据中台的原因,数据处理的技术已经是核心竞争力。在一个完备的技术架构中,通常也会由应用系统以及数据系统构成。应用系统负责处理业务逻辑,而数据系统负责处理数据。
传统的数据系统就是所谓的『大数据』技术,这是一个被创造出来的名词,代表着新的技术门槛。近几年得益于产业的发展、业务的创新、数据的爆发式增长以及开源技术的广泛应用,经历多年的磨炼以及在广大开发者的共建下,大数据的核心组件和技术架构日趋成熟。特别是随着云的发展,让『大数据』技术的使用门槛进一步降低,越来越多的业务创新会由数据来驱动完成。
『大数据』技术会逐步向轻量化和智能化方向发展,最终也会成为一个研发工程师的必备技能之一,而这个过程必须是由云计算技术来驱动以及在云平台之上才能完成。应用系统和数据系统也会逐渐融合,数据系统不再隐藏在应用系统之后,而是也会贯穿在整个业务交互逻辑。传统的应用系统,重点在于交互。而现代的应用系统,在与你交互的同时,会慢慢的熟悉你。数据系统的发展驱动了业务系统的发展,从业务化到规模化,再到智能化。
向规模化和智能化的发展,仍然存在一定的技术门槛。成熟的开源技术的应用能让一个大数据系统的搭建变得简单,同时大数据架构也变得很普遍,例如广为人知的Lambda架构,一定程度上降低了技术的入门门槛。但是对数据系统的后续维护,例如对大数据组件的规模化应用、运维管控和成本优化,需要掌握大数据、分布式技术及复杂环境下定位问题的能力,仍然具备很高的技术门槛。
数据系统的核心组件包含数据管道、分布式存储和分布式计算,数据系统架构的搭建会是使用这些组件的组合拼装。每个组件各司其职,组件与组件之间进行上下游的数据交换,而不同模块的选择和组合是架构师面临的最大的挑战。
本篇文章主要面向数据系统的研发工程师和架构师,我们会首先对数据系统核心组件进行拆解,介绍每个组件下对应的开源组件以及云上产品。之后会深入剖析数据系统中结构化数据的存储技术,介绍阿里云Tablestore选择哪种设计理念来更好的满足数据系统中对结构化数据存储的需求。
上图是一个比较典型的技术架构,包含应用系统和数据系统。这个架构与具体业务无关联,主要用于体现一个数据应用系统中会包含的几大核心组件,以及组件间的数据流关系。应用系统主要实现了应用的主要业务逻辑,处理业务数据或应用元数据等。数据系统主要对业务数据及其他数据进行汇总和处理,对接BI、推荐或风控等系统。整个系统架构中,会包含以下比较常见的几大核心组件:
对于数据存储组件我们再进一步分析,当前各类数据存储组件的设计是为满足不同场景下数据存储的需求,提供不同的数据模型抽象,以及面向在线和离线的不同的优化偏向。我们来看下下面这张详细对比表:
分类 | 存储成本 | 数据规模 | 数据访问特征 | 查询性能 | 常见数据类型 | 典型产品 |
---|---|---|---|---|---|---|
关系数据库 | 高 | 中 | 强一致事务型访问,关联查询 | 高,支持SQL查询语言,关联查询和索引加速,对复杂条件过滤查询和检索支持较弱。 | 交易、账单、应用元数据等关系数据 | Oracle,MySQL |
高速缓存 | 极高 | 低 | 低延迟Key-Value随机查询 | 极高,满足高速Key-Value形式结果数据查询,或者是高速的内存数据交换通道。 | 复杂结果集数据,或者是需要通过内存高速交换的数据。 | Redis |
搜索引擎 | 高 | 高 | 多字段联合条件过滤,全文检索 | 高,对复杂条件过滤查询和检索支持较好,支持数据相关性排序,也支持轻量级数据分析。 | 面向搜索查询的数据 | Elasticsearch,OpenSearch |
非结构化大数据存储 | 低 | 高 | 读取单个数据文件,或者是大批量扫描文件集 | 面向吞吐优化,为在线查询和离线计算都提供高吞吐的数据读取,提供极为出色的高吞吐数据写入能力。 | 图片和视频数据,数据库归档数据 | OSS,HDFS |
结构化大数据存储 | 低 | 高 | 单行随机访问,或者是大批量范围扫描 | 首先满足数据高吞吐写入以及大规模存储,数据缓存和索引技术提供高并发低延迟的数据访问,面向离线计算也提供高吞吐的数据扫描。 | 通常作为关系数据库的补充,存储历史归档数据。或者是一些非关系模型数据,例如时序、日志等。 | HBase,Cassandra,Tablestore(OTS) |
在数据系统架构中,我们可以看到会存在多套存储组件。对于这些存储组件中的数据,有些是来自应用的直写,有些是来自其他存储组件的数据复制。例如业务关系数据库的数据通常是来自业务,而高速缓存和搜索引擎的数据,通常是来自业务数据库的数据同步与复制。不同用途的存储组件有不同类型的上下游数据链路,我们可以大概将其归类为主存储和辅存储两类,这两类存储有不同的设计目标,主要特征为:
为何会有主存储和辅存储的存在?能不能统一存储统一读写,满足所有场景的需求呢?目前看还没有,存储引擎的实现技术有多种,选择行存还是列存,选择B+tree还是LSM-tree,存储的是不可变数据、频繁更新数据还是时间分区数据,是为高速随机查询还是高吞吐扫描设计等等。数据库产品目前也是分两类,TP和AP,虽然在往HTAP方向走,但实现方式仍然是底层存储分为行存和列存。
再来看主辅存储在实际架构中的例子,例如关系数据库中主表和二级索引表也可以看做是主与辅的关系,索引表数据会随着主表数据而变化,强一致同步并且为某些特定条件组合查询而优化。关系数据库与高速缓存和搜索引擎也是主与辅的关系,采用满足最终一致的数据同步方式,提供高速查询和检索。在线数据库与数仓也是主与辅的关系,在线数据库内数据集中复制到数仓来提供高效的BI分析。
这种主与辅的存储组件相辅相成的架构设计,我们称之为『派生数据体系』。在这个体系下,最大的技术挑战是数据如何在主与辅之间进行同步与复制。
『派生数据体系』是一个比较重要的技术架构设计理念,其中CDC技术是更好的驱动数据流动的关键手段。具备CDC技术的存储组件,才能更好的支撑数据派生体系,从而能让整个数据系统架构更加灵活,降低了数据一致性设计的复杂度,从而来面向高速迭代设计。可惜的是大多数存储组件不具备CDC技术,例如HBase。而阿里云Tablestore具备非常成熟的CDC技术,CDC技术的应用也推动了架构的创新,这个在下面的章节会详细介绍。
一个好的产品,在产品内部会采用派生数据架构来不断扩充产品的能力,能将派生的过程透明化,内部解决数据同步、一致性及资源配比问题。而现实中大多数技术架构采用产品组合的派生架构,需要自己去管理数据同步与复制等问题,例如常见的MySQL+Elasticsearch,或HBase+Solr等。这种组合通常被忽视的最大问题是,在解决CDC技术来实时复制数据后,如何解决数据一致性问题?如何追踪数据同步延迟?如何保证辅存储与主存储具备相同的数据写入能力?
架构师在做架构设计时,最大的挑战是如何对计算组件和存储组件进行选型和组合,同类的计算引擎的差异化相对不大,通常会优先选择成熟和生态健全的计算引擎,例如批量计算引擎Spark和流计算引擎Flink。而对于存储组件的选型是一件非常有挑战的事,存储组件包含数据库(又分为SQL和NoSQL两类,NoSQL下又根据各类数据模型细分为多类)、对象存储、文件存储和高速缓存等不同类别。带来存储选型复杂度的主要原因是架构师需要综合考虑数据分层、成本优化以及面向在线和离线的查询优化偏向等各种因素,且当前的技术发展还是多样化的发展趋势,不存在一个存储产品能满足所有场景下的数据写入、存储、查询和分析等需求。有一些经验可以分享给大家:
结构化大数据存储在数据系统中是一个非常关键的组件,它起的一个很大的作用是连接『在线』和『离线』。作为数据中台中的结构化数据汇总存储,用于在线数据库中数据的汇总来对接离线数据分析,也用于离线数据分析的结果集存储来直接支持在线查询或者是数据派生。根据这样的定位,我们总结下对结构化大数据存储的几个关键需求。
大规模数据存储
结构化大数据存储的定位是集中式的存储,作为在线数据库的汇总(大宽表模式),或者是离线计算的输入和输出,必须要能支撑PB级规模数据存储。
高吞吐写入能力
数据从在线存储到离线存储的转换,通常是通过ETL工具,T+1式的同步或者是实时同步。结构化大数据存储需要能支撑多个在线数据库内数据的导入,也要能承受大数据计算引擎的海量结果数据集导出。所以必须能支撑高吞吐的数据写入,通常会采用一个为写入而优化的存储引擎。
丰富的数据查询能力
结构化大数据存储作为派生数据体系下的辅存储,需要为支撑高效在线查询做优化。常见的查询优化包括高速缓存、高并发低延迟的随机查询、复杂的任意字段条件组合查询以及数据检索。这些查询优化的技术手段就是缓存和索引,其中索引的支持是多元化的,面向不同的查询场景提供不同类型的索引。例如面向固定组合查询的基于B+tree的二级索引,面向地理位置查询的基于R-tree或BDK-tree的空间索引或者是面向多条件组合查询和全文检索的倒排索引。
存储和计算成本分离
存储计算分离是目前一个比较热的架构实现,对于一般应用来说比较难体会到这个架构的优势。在云上的大数据系统下,存储计算分离才能完全发挥优势。存储计算分离在分布式架构中,最大的优势是能提供更灵活的存储和计算资源管理手段,大大提高了存储和计算的扩展性。对成本管理来说,只有基于存储计算分离架构实现的产品,才能做到存储和计算成本的分离。
存储和计算成本的分离的优势,在大数据系统下会更加明显。举一个简单的例子,结构化大数据存储的存储量会随着数据的积累越来越大,但是数据写入量是相对平稳的。所以存储需要不断的扩大,但是为了支撑数据写入或临时的数据分析而所需的计算资源,则相对来说比较固定,是按需的。
数据派生能力
一个完整的数据系统架构下,需要有多个存储组件并存。并且根据对查询和分析能力的不同要求,需要在数据派生体系下对辅存储进行动态扩展。所以对于结构化大数据存储来说,也需要有能扩展辅存储的派生能力,来扩展数据处理能力。而判断一个存储组件是否具备更好的数据派生能力,就看是否具备成熟的CDC技术。
计算生态
数据的价值需要靠计算来挖掘,目前计算主要划为批量计算和流计算。对于结构化大数据存储的要求,一是需要能够对接主流的计算引擎,例如Spark、Flink等,作为输入或者是输出;二是需要有数据派生的能力,将自身数据转换为面向分析的列存格式存储至数据湖系统;三是自身提供交互式分析能力,更快挖掘数据价值。
满足第一个条件是最基本要求,满足第二和第三个条件才是加分项。
目前开源界比较知名的结构化大数据存储是HBase和Cassandra,Cassandra是WideColumn模型NoSQL类别下排名Top-1的产品,在国外应用比较广泛。但这里我们重点提下HBase,因为在国内的话相比Cassandra会更流行一点。
HBase是基于HDFS的存储计算分离架构的WideColumn模型数据库,拥有非常好的扩展性,能支撑大规模数据存储,它的优点为:
HBase有其突出的优点,但也有几大不可忽视的缺陷:
国内的高级玩家大多会基于HBase做二次开发,基本都是在做各种方案来弥补HBase查询能力弱的问题,根据自身业务查询特色研发自己的索引方案,例如自研二级索引方案、对接Solr做全文索引或者是针对区分度小的数据集的bitmap索引方案等等。总的来说,HBase是一个优秀的开源产品,有很多优秀的设计思路值得借鉴。
Tablestore是阿里云自研的结构化大数据存储产品,具体产品介绍可以参考官网以及权威指南。Tablestore的设计理念很大程度上顾及了数据系统内对结构化大数据存储的需求,并且基于派生数据体系这个设计理念专门设计和实现了一些特色的功能。
Tablestore的设计理念一方面吸收了优秀开源产品的设计思路,另一方面也是结合实际业务需求演化出了一些特色设计方向,简单概括下Tablestore的技术理念:
多元化索引
Tablestore提供多种索引类型可选择,包含全局二级索引和多元索引。全局二级索引类似于传统关系数据库的二级索引,能为满足最左匹配原则的条件查询做优化,提供低成本存储和高效的随机查询和范围扫描。多元索引能提供更丰富的查询功能,包含任意列的组合条件查询、全文搜索和空间查询,也能支持轻量级数据分析,提供基本的统计聚合函数,两种索引的对比和选型可参考这篇文章。
通道服务
通道服务是Tablestore的CDC技术,是支撑数据派生体系的核心功能,具体能力可参考这篇文章。能够被利用在异构存储间的数据同步、事件驱动编程、表增量数据实时订阅以及流计算场景。目前在云上Tablestore与Blink能无缝对接,也是唯一一个能直接作为Blink的stream source的结构化大数据存储。
大数据处理架构是数据系统架构的一部分,其架构发展演进了多年,有一些基本的核心架构设计思路产出,例如影响最深远的Lambda架构。Lambda架构比较基础,有一些缺陷,所以在其基础上又逐渐演进出了Kappa、Kappa+等新架构来部分解决Lambda架构中存在的一些问题,详情介绍可以看下这篇文章的介绍。Tablestore基于CDC技术来与计算引擎相结合,基于Lambda架构设计了一个全新的Lambda plus架构。
Lambda架构的核心思想是将不可变的数据以追加的方式并行写到批和流处理系统内,随后将相同的计算逻辑分别在流和批系统中实现,并且在查询阶段合并流和批的计算视图并展示给用户。基于Tablestore CDC技术我们将Tablestore与Blink进行了完整对接,可作为Blink的stream source、dim和sink,推出了Lambda plus架构:
本篇文章我们谈了数据系统架构下的核心组件以及关于存储组件的选型,介绍了派生数据体系这一设计理念。在派生数据体系下我们能更好的理清存储组件间的数据流关系,也基于此我们对结构化大数据存储这一组件提了几个关键需求。阿里云Tablestore正是基于这一理念设计,并推出了一些特色功能,希望能通过本篇文章对我们有一个更深刻的了解。
原文链接
本文为云栖社区原创内容,未经允许不得转载。