openLooKeng新下推框架的介绍与实践

本文介绍了openLooKeng的新下推框架,旨在解决原有基于Rule的下推方案的局限性,如无法处理JoinNode等。新框架允许connector提供基于visitor模式的PlanOptimizers,实现更灵活的优化。通过暴露子执行计划给connector并限制仅优化所属子树,新框架可以更高效地将操作下推到数据源,充分利用数据源能力。此外,还展示了如何为connector添加connectorPlanOptimizer的步骤,并提供了示例演示。
摘要由CSDN通过智能技术生成

openLooKeng执行计划优化简介

在讲述下推框架之前,我们先来简单介绍一下openLooKeng执行计划优化的大致流程。

01.jpg

如上图所示,接收到用户SQL语句之后,SQL被转换成一个Abstract syntax tree (AST)树。AST树再被转换成逻辑执行计划树。然后,也就是执行计划优化过程中最重要的一步,使用规则(Rule)或者优化器(Optimizers)进行执行计划优化,每一个PlanOptimizer可以操作一个子执行计划树,PlanOptimizer基于统计或者经验,用一个更优的子执行计划替换当前的子树,达到优化的目的。PlanOptimizers通常是长期的经验累积得出来的一些优化规则,比如谓词下推、join reorder等等。PlanOptimizers可以存储一些物理执行信息在ConnectorHandle中。新下推框架则工作在这一层。

得到最优的执行计划之后,逻辑执行计划被转换成物理执行计划,然后被分片,分割成按照stage执行的一个个子树,最终调度到worker上执行。

PrestoSql下推方案介绍

最初,openLooKeng是从PrestoSql演进而来,在其基础上增加了很多功能特性,以及大量的性能优化。在讲述openLooKeng的新下推框架之前,先大概介绍其原下推方案。

  • 根据社区的讨论,PrestoSql原下推框架有一些目标:

1)使用现有的Rule或Optimizer的框架,而且不是使用基于visitor模式的PlanOptimizers来实现下推,同时能够让connector提供转换rules来实现下推;

2)并不是建立一个原生的机制来支持所有操作的下推。

  • 先来看看prestoSql的执行过程:

1)首先,引入一些列的下推规则,每一个规则负责下推相应的操作到TableScan操作中,比如PushFilterIntoConnector, PushProjectionIntoConnector, PushAggregationIntoConnector等等;

2)上述的这些rules通过指定的metadata调用与connectors交互,如果connector支持这个操作下推,操作则被下推到TableScan操作,同时在connectorTableHadle中记录相关信息。

  • 下面以PushFilterIntoConnector为例说明。

openLooKeng是一个开源的分布式SQL查询引擎,它具有以下关键特性: 1. 跨源查询:openLooKeng可以在多个数据源之间执行SQL查询,包括关系型数据库、NoSQL数据库和数据湖等。 2. 分布式查询:openLooKeng可以在大规模集群上进行分布式查询,以实现高性能和可伸缩性。 3. 跨数据中心查询:openLooKeng支持在不同数据中心之间执行SQL查询,使得跨地域或全球范围内的数据分析成为可能。 4. 优化器和执行引擎:openLooKeng具有强大的查询优化器和执行引擎,可以自动优化查询计划以提高查询性能。 5. 多种数据格式支持:openLooKeng可以处理多种数据格式,包括Parquet、ORC、Avro等,以适应不同的数据存储方式。 6. 兼容性:openLooKeng基于ANSI SQL标准,因此可以与现有的SQL工具和应用程序无缝集成。 基于这些关键特性,openLooKeng适用于各种业务场景,包括但不限于: 1. 数据湖分析:openLooKeng可以对分布在不同数据湖中的数据进行联合查询和分析,帮助用户更好地理解和利用数据湖中的数据。 2. 实时分析:openLooKeng可以处理实时数据流,将实时数据与批处理数据进行联合分析,提供实时的洞察和决策支持。 3. 数据集成:openLooKeng可以对多个数据源进行统一查询和集成分析,帮助用户在不同数据源之间进行数据交互和数据集成。 4. 跨地域数据分析:openLooKeng支持跨数据中心的查询,可以在全球范围内进行数据分析,提供全局视角的数据洞察。 总之,openLooKeng是一个功能强大的分布式SQL查询引擎,适用于各种业务场景,可以帮助用户解决跨源、跨数据中心的SQL查询和数据分析问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [数据虚拟化引擎openLooKeng介绍](https://blog.csdn.net/openLooKeng/article/details/115706846)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [数据虚拟化引擎openLooKeng: 不搬运数据,只是数据的连接器](https://blog.csdn.net/penriver/article/details/122339062)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值