曾文旌的私房菜:开源数据库Greenplum Database的实现解析

本文涉及的产品
阿里云百炼推荐规格 ADB PostgreSQL,4核16GB 100GB 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
云原生数据库 PolarDB MySQL 版,通用型 2核4GB 50GB
简介: 在本次分享中,曾文旌从GPDB架构入手,辅助以SQL和优化器的案例以及对GPDB的硬件和性能的分析,对GPDB实现进行了详细解析。分享最后,他还对比了GPDB的优势和局限性,并对GPDB的未来发展进行了展望。

Greenplum DB 号称是世界上第一个开源的大规模并行数据仓库,最初是基于 PostgreSQL,现在已经添加了大量数据库方面的创新。Greenplum 提供 PD 级别数据量的强大和快速分析能力,特别是面向大数据方面的分析能力,支持大数据的超高性能分析查询。在本次分享中,曾文旌从GPDB架构入手,辅助以SQL和优化器的案例以及对GPDB的硬件和性能的分析,对GPDB实现进行了详细解析。分享最后,他还对比了GPDB的优势和局限性,并对GPDB的未来发展进行了展望。

以下是现场分享观点整理。


名词简介

6cd66e5fddc4f9ae1e6cc6b9b766f5604a64fd78

在分享开始之前,首先解释一下整个内容中最关键的几个名词:

  •  MPPMassive parallel processing)为大规模并行处理系统,一般是指多个SQL数据库节点搭建而成的数据库仓库;在执行SQL查询的时候,任务可分解到多个数据库查询,然后将结果返回给用户。
  •  MRmapreduce)是一种编程模型,结合了大规模处理并行运算编程的思想,可粗略地分成两部分,mapreduce,任何一个复杂的任务都可以拆成mapreduce的串行组合,主要思想从函数式的编程语言所借鉴过来。
  •  SNShared nothing)为存储的架构,用于存放数据,由多个完全独立的处理节点构成,每个处理节点有自己独立的处理SMP的架构,他们存储的数据没有共享的部分,独立的磁盘存放数据,多个SMP数据节点之间通过高速网络连接,协同起来完成一个复杂的任务。
  •  Data distribution 即数据分发。SN架构上,MPP完成并行任务,它们之间需要做数据的沟通,GPDB的沟通相对复杂,每个数据节点之间可以相互沟通,有的数据库产品可能只允许master和数据交流,master和其他数据节点不能相互分发数据。

ebd64e22706b30282ee0870b69c337215f68ef7c 

MPP的完整定义如上所示,它的重点首先是本地存储数据,其次是通过网络交换数据,最后是每个数据都是数据节点的一部分,它们之间没有共享。


GPDB架构特点

3ddc089530fd8c5690bcc183fe23fb824a6f82e0 

上图显示的GPDB架构图,架构中最主要的中心节点是Master Host,它可以和用户的客户端直接交互;其他的数据连接的是Segment Host,并且Segment中存放了一部分的数据;Master和Segment之间通过高速网络交换。

MPP VS MR

bbf9525ef0f43afd5af700c793f8ec1385431d82 

上图是MR的相关定义信息。显然,Hadoop主要分为两部分,一是存储部分,即分布式存储,比如熟悉的HDFS;二是大数据的计算框架,通常为MapReduce。

d9206e4fa035251bebee4a4e5a1caad2dac874ee 

Apache Hadoop是谷歌思想的一种流行的实现。整个Hadoop实现的过程中,它是作为一种开源的框架,设计思路是使用低成本的硬件和自己软件中的容错功能,容错功能由HDFS来完成。有了HDFS,Apache Hadoop很容易上一定的规模,HDFS是Hadoop做到很大集群的最主要的原因。

513d55849a52cde79d9218bae9254921542adb4d 

词频统计是MapReduce的设计思路常用的简单案例,将文本中单词出现的次数做一个统计,其过程也体现了Hadoop的处理思想。第一步MAP将数据从HDFS中读出来,将句子拆成单词形式,这是一个key-value的过程,key就是单词本身,value是词频,一般取1,其结果再存放到本地HDFS中,即入库的过程;第二步是reduce的过程,从HDFS中拉取数据,然后计算词频,将相同的key值放到一个reducer中,再将key累加起来,最后得到的结果再存回HDFS。如果再做一些更复杂的操作,就重新迭代几次,这个统称为MapReduce思想。

0af1a93d6f6f95b5f433773369a986879d2155bc 

这个思想的开源版本未被抛弃的优势在于:它完整地实现了Google思想,同时具有良好的容错,适合大数据存储和计算,并且具有廉价的可用方案(软件硬件)。但其也有很多思想是过时的,例如它只是比较简单的开源实现,只适合离线计算,同时模型抽象困难、编程困难。此外它还具有一个致命的弱点,即中间结果入库整体效率低、性能差。

虽然实现方式已经过时了,但它仍未被抛弃,而且性能还会改进。

f6cf0b47c35e6dd8a4a3d10936fd54199f4d5273 

上图显示的是MR的典型的发展方向:首先,十年前主要是MapReduce,它的编程方式不太好学习;于是就有了hive,即上面是它自己的语句,底层转换成了MapReduce的方式;再后来,由于每次入库都比较慢,则将这种方式放在内存里面做,即memory的实现方式。

0f429ab8be25cfbd12126814b13e0ccf7ac8b106 

在关系型数据库里,词频统计也很简单,一个SQL语句就可以做到。SQL语句在GPDB是兼容SQL语句的,如上图的语句中:通过一个函数从some_table表把some_column字段拆成了一列多行的形式,将其抽象成一个临时表,再对临时表进行GROUP BY,针对每个GROUP进行一次count,最后将结果计算出来。

7636e3245c6a2ba640615b722212b526881f4202 

上图是GPDB中的QUERY PLAN,通过查看SQL语句的执行计划了解执行过程以及使用的算法。上图是一个16节点的GPDB,在segment中被拆成了两部分,首先是底层的顺序扫描,读到之后用函数拆分,然后将拆分的结果作为一次哈希聚集,并通过网络的分布节点,发送到各个segment。发送方式是哈希方式,定义一个哈希分布,把需要的数据留下,把不需要的分发到需要它的segment中。另外一个segment的作用是收到这个数据,再做一个哈希聚集,最终把这个数据再发送给master节点,它的分发程度和segment一样。所以我们看到:中间的网络分发是segment实现的一个点,它能做到Hadoop相同的功能,但前提是把非结构型数据转换成结构型数据存放到关系型数据库的表里,这样性能才可以得到保证。


GPDB同类产品 

相关的MPP产品,总结如下表,在这里不一一详述。

a108889852cc7aeaa8c33372277ff1cb225e6c78 

GPDB关键特性解析

4c636c609f66fca6255b72e10abf1e4d8e519e55 

接下来解析GPDB的关键特性:

  1.  分区表是关系型数据库,GPDB做到了完整的分区表,不同类型的表都可以组成一张分区表,比如说堆表、列存储的表。另一个区别是Shared nothing hush分布。
  2.  传统的数据库支持复杂的SQL语句,完成复杂的任务,并可以通过一个SQL语句表达出来,整个语句的执行计算也好,数据读取也好,都被完全下发到了数据节点上。
  3.  关系数据库的代价模型,这也是它能做复杂SQL的关键性的原因。根据不同表的规模选取SQL语句,节点间的数据可以做相互的分发,根据该特性可以进行网络方面的优化。
  4.  传统堆表,相当于一行数据是元存储方式,多列组合成一条,存储在数据库上面,支持列存储,支持压缩数据的存储。
  5.  GPDB可以像通常的关系型数据库那样支持事务,可以做并发,但是有一定的限度。SQL语句的select并发没有问题。对于高速数据装载,GPDB可以让每一个segment同时往自己的节点上装载数据,这和传统的方式相比,性能有很大的区别,装载性能很好,有时候甚至可以把网络的带宽占满。
  6.  企业的高可用性。,支持一个高可用的部署,以镜像节点的方式,持续地提供服务。还有高速网络通信,因为不可能为每一个业务都定制表的分发方式,在TCP的基础上又增加的UDP的连接协议,显著地提高网络的传输效率。
  7.  足够稳定,功能相对完善。支持数据压缩,能够提供压缩算法的选择。开源版本支持开源的一些压缩方式,GPDB还有一个收费的压缩方式,需要的话可以购买。

a757088ebb12ab18963d5b4a2a2d8e32bccccc80 

上图是查询的执行方式。master上不存储用户数据,但是会存放表定义,有时候可通过copy的方式往master上加载数据,然后maser再向每个segment上分发数据。master支持stand by节点,stand by不能读,只是一个备份,在master节点出问题的时候,让stand by连接,继续做任务,然后再将master搭起来,实现高可用。

查询执行的任务拆分是一个简单的两个表的作用语句,它在segment中被分为了两个部分来执行,分片1扫到数据之后通过网络重分布motion节点到另外一个节点,然后它发送给本segment的另外一个节点;根据motion的定义,另一个分片扫描另外一部分表,把收到的数据作一些函数的调用,最后的数据会发送给gather motion节点。每个segment的执行方式完全一样,最后的gather motion实际上是一个master节点,它会收所有的segment数据。

f5a33d5623718dffbd6132ae5f2cd0add545b0a3

接下来说任务执行,在这里出现了gang的概念。master分发任务称为QD process,即查询分发,首先进行segment查询,多个步骤,即多个gang的方式来执行,下层会将数据往上层上传,最终汇总到QD上。

7127b032b56a5ee2c212bd2fd5ddbcb09932bd00 

我们以两个表为例,说明一下SQL语句的执行过程。表a和表b都是以id列作为分发,这里面做了一个粗暴的估计,以表里的行数出现。网络部分的cost和网络传输的数据量正相关。另一部分是用于网络通信的motion节点,它有两种类型:一是Redistribute Motion哈希重分布,二是Broadcast Motion广播。

9dbbcada8d044e88a290004ff480c2202f466168 

第一个优化器例子: A表和b表都各自有10000行,连接之后,可以看到整个的执行计划没有motion节点,因此不需要做网络重分布 。

722f634c259eaf705fa20d0f5a597be876d602a6 

若表的规模不变化,左边的是表a的分布列,id2不是分布列。b表会按照id2计算重分布,然后在所有的节点上做一个重分布,重分布b表时代价简单理解为10000;方法二是把a/b表广播出去,它们的代价是10000*16。很显然,重分布b表的代价最小,执行计划也是这么选择的,即优化器自动选择了最优的执行方式。

4e1400fc3a69a3e49ceda819eca39a296b9d7028

当a表的规模变为100,b表还是10000,表的连接方式不变。显然,广播a表的时候代价最小,重分布b代价为10000,全广播b代价为10000*16,优化器也自动选择了最优的方式。

9a3a18e190637a34750430d3a3ba1c330036ef17

如果数据规模不变,改变连接方式,连接的两个列都不是数据的分布列,很容易看出全广播a表代价最小。

47bd207478d41292b163e3fca21254ff28e14bf5

最后一个例子,不连接数据的分布列,表的大小都是10000行。定义一个id2作为重分布列,a表b表都重分布一次,对比全广播a,全广播b代价小很多,所以在这个数据规模下选择重分布AB执行方式。

794c44f84820a569a19e3f5d6618ba2b8f95d557

如图,可将优化器作如上总结:SQL比较友好,学习成本低,支持范围比较多。基于统计信息的代价模型有核心的优势,SQL语句越复杂,优势越明显。

7e029f3fb6964378ad7bba02ad0e4bea11040aa7

除此之外,还有一个高可用的部署方式,master的一个备份叫slave,它们之间通过流复制同步,master若出现问题,slave可以被激活,然后成为新的master。master和slave之间是流复制同步,半同步;segment之间是基于文件的快的同步,概念上是一个primary和mirror。segment若出现问题,有一个机制来保证继续往下提供服务,若网络闪断,primary会积攒一些数据,等网络好的时候再同步到mirror上。

687f5218c225674921d391401ebb1ceb655bb5b5

上图为高速数据装载,GPDB可以支持分布式数据装载。首先部署多个存放数据的节点,数据用web表的形式通过master请求;master请求之后,所有的segment通过GPFD的数据分发服务,GPFD收到数据的请求,然后给所有segment发数据,对等随机地发送,也可以部署多个GPFD,将数据平均地分配到每一个中, segment解析数据,和重分布有点类似,留下自己的那部分数据,存到本地segment中,定向发送不属于自己的数据。segment是定向发送,GPFD发给segment是随机发送。所以说如果整个网络足够好,装载速度会非常快,可以装载全量数据,也可以批量装载。


GPDB硬件和性能

283ea45d86a627aa3fedf8ca9d25cc34985c3257

segment是存储和计算数据的节点,segment越多,并行程度越高。建议为每个segment至少分配一个物理核CPU,8G内存,网络至少千兆以上,因为刚刚列举的很多特性有网络要求;硬盘一般为RAID 5。mirror状态不会消耗很多CPU,但是会消耗对等的网络。

03f503d5106dd3cb225bb1ee9ba58ee15b7de4d6

标准的TPCH测试用的比较多,很容易找到开源项目,最大测1T左右的数据;PC server和Hadoop比,性能好很多;SQL越复杂,GPDB性能越好,好的可能到几十倍。除了排序需要将数据缓存到磁盘,大部分的数据在内存里,通过网络做高速的分发,网络的分发经过优化,所以性能非常好。数据在内存是流式的执行方式,正常情况,一个数据被扫描到一个节点,处理完之后立马发送到上层节点,然后再往上发。


GPDB优势和局限性

f50d673ce736b9d092a2c64c1df0e30879e0b88a

GPDB的优势在于它可以做网络数据同步,能够控制整个SQL语句的队列,控制内存的消耗;还可以用它来做资源的限制,根据自己硬件的需要控制资源;此外,每个模块经过多年的打磨,优化很好。

44cd58ddb13388670e118f0e2ef406fb2e837511

GPDB的局限性,有如下几种:

  •  扩展性,它不像HadoopHDFS可以扩展到上千台,有理论瓶颈。从使用来说,比如说扩容,扩容之后所有的整个数据都需要重分布,存储方式限制了其继续往上扩展,运维的成本有可能会越来越高,当然,几十台的情况下还是游刃有余的。
  •  增量入库, GP提供了一个其他的方式,来做到类似的功能。把增量成批地导出到文本,然后再成批地导入到GPDB里面去,最后再用合并的方式合并到原有的数据库,变相做到增量入库。
  •  容错,上面提到通过备份的方式容错,这个有一定的局限性。
  •  改进空间,比如,它支持的存储方式有列存储,列存储就是一列一个文件,用了分区表再用列存储,磁盘上的文件就会非常多,如果说再来一个并发的查询,由于PG是多进程的方式,在文件OS上同时打开,打开的个数就会特别多。
 

GPDB的发展

3f01a625ba45f5f16bcc13537a07b5b94ba5107e

GPDB未来发展有几个方面:

  •  新一代优化器,也是开源部分,在一些情况下,会比原有的GPDB优化器更好,尤其是在算多个分区表相互作用的情况下。
  • CPU的消耗会明显减少,整个CPU运行的效率会提高,网上发布了测试的版本,从结果来看,性能不错。
  •  其他数据库没有UDP通信的优化,所以GPDB发展的较好。
  •  内部发展方向,用HDFS提高容错性,数据和计算分离。每个HDFS节点都会挂segment节点的进程,当需要的时候,启动segment计算;不需要的时候不会存在。


总结

45b8fbd2eb33735b7933c95c13569998f4c2ba9b

最后简单地总结一下: GPDB的开源,在TP级别游刃有余,解决方案非常好,应用性较好,比Hadoop有着明显的优势;但是以后Hadoop也会朝着相同的方向发展。另一方面,MR和MPP的关系是相互学习,能够融合互相的优点。相当于MR把一些计算优化,使性能更好;MPP也会学习Hadoop把数据放在HDFS上,就这样实现相互融合,它们之间的一些界限作为并行计算来说越来越模糊,未来也会有很多开源或者商业的产品,在这上面诞生。


相关云产品:https://www.aliyun.com/product/gpdb

相关文章
|
27天前
|
数据库 索引
深入探索数据库索引技术:回表与索引下推解析
【10月更文挑战第15天】在数据库查询优化的领域中,回表和索引下推是两个核心概念,它们对于提高查询性能至关重要。本文将详细解释这两个术语,并探讨它们在数据库操作中的作用和影响。
46 3
|
1月前
|
存储 NoSQL 关系型数据库
数据库技术深度解析:从基础到进阶
【10月更文挑战第17天】数据库技术深度解析:从基础到进阶
59 0
|
26天前
|
存储 负载均衡 监控
数据库多实例的深入解析
【10月更文挑战第24天】数据库多实例是一种重要的数据库架构方式,它为数据库的高效运行和灵活管理提供了多种优势。在实际应用中,需要根据具体的业务需求和技术环境,合理选择和配置多实例,以充分发挥其优势,提高数据库系统的性能和可靠性。随着技术的不断发展和进步,数据库多实例技术也将不断完善和创新,为数据库管理带来更多的可能性和便利。
93 57
|
21天前
|
存储 SQL Apache
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
Apache Doris 是一个基于 MPP 架构的高性能实时分析数据库,以其极高的速度和易用性著称。它支持高并发点查询和复杂分析场景,适用于报表分析、即席查询、数据仓库和数据湖查询加速等。最新发布的 2.0.2 版本在性能、稳定性和多租户支持方面有显著提升。社区活跃,已广泛应用于电商、广告、用户行为分析等领域。
Apache Doris 开源最顶级基于MPP架构的高性能实时分析数据库
|
17天前
|
自然语言处理 并行计算 数据可视化
免费开源法律文档比对工具:技术解析与应用
这款免费开源的法律文档比对工具,利用先进的文本分析和自然语言处理技术,实现高效、精准的文档比对。核心功能包括文本差异检测、多格式支持、语义分析、批量处理及用户友好的可视化界面,广泛适用于法律行业的各类场景。
|
28天前
|
存储 关系型数据库 MySQL
MySQL vs. PostgreSQL:选择适合你的开源数据库
在众多开源数据库中,MySQL和PostgreSQL无疑是最受欢迎的两个。它们都有着强大的功能、广泛的社区支持和丰富的生态系统。然而,它们在设计理念、性能特点、功能特性等方面存在着显著的差异。本文将从这三个方面对MySQL和PostgreSQL进行比较,以帮助您选择更适合您需求的开源数据库。
104 4
|
1月前
|
存储 JSON Ubuntu
时序数据库 TDengine 支持集成开源的物联网平台 ThingsBoard
本文介绍了如何结合 Thingsboard 和 TDengine 实现设备管理和数据存储。Thingsboard 中的“设备配置”与 TDengine 中的超级表相对应,每个设备对应一个子表。通过创建设备配置和设备,实现数据的自动存储和管理。具体操作包括创建设备配置、添加设备、写入数据,并展示了车辆实时定位追踪和车队维护预警两个应用场景。
61 3
|
1月前
|
Web App开发 SQL 数据库
使用 Python 解析火狐浏览器的 SQLite3 数据库
本文介绍如何使用 Python 解析火狐浏览器的 SQLite3 数据库,包括书签、历史记录和下载记录等。通过安装 Python 和 SQLite3,定位火狐数据库文件路径,编写 Python 脚本连接数据库并执行 SQL 查询,最终输出最近访问的网站历史记录。
|
1月前
|
NoSQL 关系型数据库 MySQL
AWS Database Migration Service 助力数据库搬迁
AWS Database Migration Service 助力数据库搬迁
|
1月前
|
SQL 开发框架 .NET
ASP.NET连接SQL数据库:实现过程与关键细节解析an3.021-6232.com
随着互联网技术的快速发展,ASP.NET作为一种广泛使用的服务器端开发技术,其与数据库的交互操作成为了应用开发中的重要环节。本文将详细介绍在ASP.NET中如何连接SQL数据库,包括连接的基本概念、实现步骤、关键代码示例以及常见问题的解决方案。由于篇幅限制,本文不能保证达到完整的2000字,但会确保

推荐镜像

更多
下一篇
无影云桌面