领先一步,效率翻倍:PieCloudDB Database 预聚集特性让查询速度飞起来!
在大数据时代,如何有效地管理和处理海量数据成为了企业面临的核心挑战。为此,拓数派推出了首款数据计算引擎 PieCloudDB Database,作为一款全新的云原生虚拟数仓,旨在提供更高效、更灵活的数据处理解决方案。
PieCloudDB 的设计理念源于对用户使用体验和查询效率的深度理解。在实现存算分离的同时,PieCloudDB 专门设计和打造了全新的存储引擎「简墨」等模块。针对云场景和分析型场景,PieCloudDB 还设计了高效的预聚集(Pre-Aggregate)特性。本文将详细介绍 PieCloudDB 如何运用预聚集技术优化数据处理流程,改善用户体验。
作为云原生虚拟数仓,PieCloudDB 充分借助云计算所提供的基础设施服务,包括大规模分布式集群、虚拟机、容器等。这些特性使得 PieCloudDB 能更好地适应动态的和不断变化的工作负载需求。同时,PieCloudDB 也积极拓展其自身的特性,实现高可用、易扩展和弹性伸缩,以满足企业不断增长的业务需求。
PieCloudDB 实现了一个重要创新功能:预聚集(Pre-Aggregate)。 该功能通过 PieCloudDB 的全新的存储引擎「简墨」(JANM),在数据插入时即时计算数据列的 Aggregate 信息,并将其预先保存以供后续使用。这种方法摒弃了在查询时进行复杂计算的传统方式,从而大大提升了查询速度。此外,由于聚合数据保存在文件中,可以实现快速访问并直接应用于查询。
PieCloudDB 会根据用户的查询自动生成带有 Pre-Aggregate 的计划,使得查询过程尽可能地快速且准确。 当需要聚合数据时,系统会检查预存储的聚合值,并直接读取符合条件的 Aggregate 数据。这样避免了查询过程中扫描整个数据集的需求,可以大幅提升查询速度。
对于部分满足条件的块,PieCloudDB 将会回归原来的处理方式计算 Aggregate 值。 这样既能利用已经预聚合的数据,又只需计算缺少的部分,从而降低计算成本并提高运算效率。
1 预聚集的原理
为了能够增加 Aggregate 的查询性能,PieCloudDB 采用了以「空间」换取「时间」的策略,在写入数据的时候,在存储层中将相关的 Aggregate 进行预先计算并保存,从而在查询的时候可以快速找到需要的 Aggregate 数据。
上面解决了 Aggregate 数据来源问题,下面将介绍如何拿到预先计算的 Aggregate 数据。为了能够实现正确获取下推的 Aggregate 数据,PieCloudDB 的优化器与执行器被进一步改造,增加了两个新的 Pre-Aggregate 计算节点。改造前后的计划树(plan tree) 的对比如下图所示:
改造前后 plan tree 对比图
存储引擎「简墨」会在数据插入时,即时更新 Aggregate 信息。在上图中的 Pre-Aggregate 计算节点会从 AM(access method)中取出预先计算的 Aggregate 数据,如果没有找到合适的 Aggregate 数据,Pre-Aggregate 计算节点也会从 AM 中找出满足条件的 tuple 计算出对应的 Aggregate 数据,返回给上层计算节点使用。这样就解决了怎么正确找到下推的 Aggregate 数据的问题。
Pre-Aggregate 是 OLAP 优化技术中 Zone Maps 的具体实现。即预先计算一批元组属性值的聚合并预先保存,数据库检查预计算的聚集信息决定是否要访问该 block。即上面所述的如果找到可用的 Aggregate 数据则直接返回,否则访问该 block 检索具体元组。
对于带条件的 Pre-Aggregate 来说,其效果取决于预先计算所涉及的数据范围。PieCloudDB 将预聚集范围缩小至块文件,针对每个块文件分别进行预计算存储,从而保证带条件的预聚集查询效果。
2 预聚集的使用演示
下面给出了如何开启 Preagg Block Scan 以及支持 Block Skipping 的 Preagg Bitmap Block Scan 的使用方式。最后给出了对应的性能对比图。
2.1 Preagg Block Scan 使用方式
-- 创建 t 表 create table t(a int, b int, c int); -- 写入三行数据 insert into t values(1,2,3); insert into t values(3,3,5); insert into t values(4,4,6); -- 开启 preagg,默认是开启的 set pdb_enable_preagg = on; -- 执行如下的 query explain (costs off) select sum(b), avg(c), count(*) from t; QUERY PLAN ------------------------------------------------ Finalize Aggregate -> Gather Motion 3:1 (slice1; segments: 3) -> Pre-Aggregate Block Scan on t Optimizer: Postgres query optimizer (4 rows) -- 开启后的执行结果 select sum(b), avg(c), count(*) from t; sum | avg | count -----+--------------------+------- 9 | 4.6666666666666667 | 3 (1 row) -- 关闭 preagg set pdb_enable_preagg = off; -- 执行同一条 query explain (costs off) select sum(b), avg(c), count(*) from t; QUERY PLAN ------------------------------------------------ Aggregate -> Gather Motion 3:1 (slice1; segments: 3) -> Seq Scan on t Optimizer: Postgres query optimizer (4 rows) -- 关闭后的执行结果 select sum(b), avg(c), count(*) from t; sum | avg | count -----+--------------------+------- 9 | 4.6666666666666667 | 3 (1 row)
2.2 Preagg Bitmap Block Scan 使用方式
create table t(a int, b int); insert into t values(generate_series(1, 20), generate_series(100, 120)); insert into t values(generate_series(21, 60), generate_series(121, 160)); -- 开启 preagg,默认是开启的 set pdb_enable_preagg = on; -- 下面是开启 Pre-Aggregate Bitmap Block Scan 的几个 guc set enable_seqscan = off; set enable_bitmapscan = on; set enable_indexscan = on; -- 执行如下的 query explain (costs off) select max(a), sum(a) from t where a > 10 and a < 50; QUERY PLAN --------------------------------------------------------------- Finalize Aggregate -> Gather Motion 3:1 (slice1; segments: 3) -> Partial Aggregate -> Pre-Aggregate Bitmap Block Scan on t Recheck Cond: ((a > 10) AND (a < 50)) -> Bitmap Index Scan on t Index Cond: ((a > 10) AND (a < 50)) Optimizer: Postgres query optimizer (8 rows) -- 开启后的执行结果 select max(a), sum(a) from t where a > 10 and a < 50; max | sum -----+------ 49 | 1170 (1 row) -- 关闭 preagg set pdb_enable_preagg = off; -- 执行同一条 query explain (costs off) select max(a), sum(a) from t where a > 10 and a < 50; QUERY PLAN --------------------------------------------------------------- Finalize Aggregate -> Gather Motion 3:1 (slice1; segments: 3) -> Partial Aggregate -> Bitmap Heap Scan on t Recheck Cond: ((a > 10) AND (a < 50)) -> Bitmap Index Scan on t Index Cond: ((a > 10) AND (a < 50)) Optimizer: Postgres query optimizer (8 rows) -- 关闭后的执行结果 select max(a), sum(a) from t where a > 10 and a < 50; max | sum -----+------ 49 | 1170 (1 row)
2.3 性能对比
测试表:
create table preaggdata (a int, b int);
测试语句:
explain analyze select sum(a), avg(a), count(*), max(b) from preaggdata;
耗时对比图如下所示:
耗时对比图
从上面的测试数据和对比图可以看出,未开启 Pre-Agg 时,随着数据量的增大,耗时不断增大,且增加的速度也会越来越快;而开启 Pre-Agg 时,耗时是平稳的增长的,增长的速度也不快。当数据量达到 10000K 时,实现了近 28 倍的速度提升。
3 预聚集未来演变之路
目前, Pre-Aggregate 采用「空间」换「时间」的策略来提升性能效率。为了扩大 Pre-Aggregate 的应用范围,优化用户体验,我们将不断推动技术研发,扩大应用场景,并提供更加丰富、多元的功能。
无论是通过优化数据处理方式,拓展支持的函数类型,还是引进新的查询处理机制,我们都在锲而不舍地努力实现这一目标。相信很快,Pre-Aggregate 将能够为复杂的查询场景提供更高效、更精准的解决方案,从而逐步深化其在数据分析和处理领域的应用影响力。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
唱衰 PHP?这些言论别太离谱~《PHP 综合现状分析报告》来了
PHP这门有着近三十年历史的编程语言曾几度被唱衰,“PHP将亡”的言论伴随着“PHP是最好的语言”的黑色幽默,多年来屡见不鲜。 那PHP的现状究竟如何? 为拨开PHP语言周遭的层层迷雾,禅道项目管理软件团队从近两年各方发布的PHP应用现状报告、2023年PHP最新动态以及对PHP社区用户的深入访谈等维度出发,整理编辑出了一份全面、真实、客观的《2022-2023年度PHP综合现状分析报告》。希望这份报告能帮助行业从业者更好地理解PHP语言的现状与趋势,为相关决策提供参考依据。在PHP的应用方面,WakaTime发布的年度使用数据显示,2022年使用较为广泛的编程语言中,PHP以11%的比例位居第三;SlashData公司发布的2022年开发者报告显示,在过去24个月内,PHP的社区排名相对稳定在第五、六名;W3 Techs发布的全球前1000万个网站的编程语言分析报告显示,截至2023年8月,使用最为广泛的服务端编程语言中,PHP以76.8%的比例位居第一……PHP语言的应用现状还是呈整体稳定的形势。 而PHP基金会也发布报告,表示计划2023年进一步扩展开发团队,支撑PHP社区的更多...
- 下一篇
数仓实时场景下表行数估算不准确引起的的性能瓶颈问题案例
本文分享自华为云社区《GaussDB(DWS)性能调优:实时场景下表行数估算不准确引起的的性能瓶颈问题案例》,作者: O泡果奶~。 本文针对实时场景下SQL语句因表行数估算不准确而导致语句执行超时报错的案例进行分析。 1、【问题描述】 实时场景下,select查询语句执行时间过长,该语句verbose执行计划中存在nestloop,且使用hint(set (enable_index_nestloop off)) 无法生效。 2、【原始语句】 select * from ( select wo.work_order_id /*工单id*/, wo.work_order_code /*工单编码*/, wo.work_order_name /*工单名称*/, wo.work_order_level /*工单层级(第一层级(未拆分工单/父工单):1,第二层级(子工单):10)*/, decode(wo.work_order_level,1, '第一层级(未拆分工单/父工单)', 10,'第二层级(子工单)') as work_order_level_desc /*工单层级描述*/, ...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- MySQL8.0.19开启GTID主从同步CentOS8
- CentOS8安装Docker,最新的服务器搭配容器使用
- Linux系统CentOS6、CentOS7手动修改IP地址
- 2048小游戏-低调大师作品
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS8编译安装MySQL8.0.19
- CentOS6,CentOS7官方镜像安装Oracle11G
- CentOS7,8上快速安装Gitea,搭建Git服务器
- SpringBoot2整合Thymeleaf,官方推荐html解决方案