成为 Apache 顶级项目贡献者之路:Apache Doris 的语法迁移攻略

Apache Doris 是一个开源的 MPP(大规模并行处理)数据库,作为 Apache 顶级项目之一,它提供了高性能、高扩展性的分析能力。在 Doris 的发展过程中,新优化器在增强开箱即用的能力方面扮演了重要角色,但是有些老优化器的语法在新优化器还没有支持,因此有了这个旧优化器语法迁移到新优化器的任务。本文将带你深入了解如何实现一个语法迁移任务,探索从入门到贡献者的全过程,助力您成为 Apache Doris Contributor。

🛠 任务内容

您将协助将一个 DDL 命令从旧优化器(Old Planner)迁移到我们的新优化器 (Nereids Optimizer)。这项工作包括理解 DDL 命令在旧系统中的处理结构,并将其适配到 Nereids 的新执行流程中。

🎯 适合您的理由

- 分步骤指导:迁移方案包含解析、校验和执行等结构化步骤,简单易学。
- 导师支持和社区帮助:团队随时为您解答疑问,这个任务也将让您熟悉我们的核心组件和友好的开发者社区。
- 技能提升:您将学习DDL命令处理逻辑及高级代码库的工作方式。

💡 如何开始

- 了解 旧优化器 中 DDL 命令的结构(解析、校验、执行)。
- 将这些步骤适配到 Nereids 优化器 的工作流程中(使用 validate() 进行语法校验,并用 run() 进行执行)。
- 测试您的更改并提交拉取请求!

即使您对某些部分不熟悉也没关系——我们会为您提供帮助!加入我们,让项目更快、更智能、更出色。让我们开始吧!🎉

**Demo PR 示例(https://github.com/apache/doris/pull/43103)
Issues Project(https://github.com/orgs/apache/projects/424/views/1)**

目录

  • 完成一个迁移任务的主要流程
  • 实现迁移任务的框架和原理
  • 实现一个迁移任务的原则
  • 如何书写迁移任务的测试
  • 如何实现一个迁移任务
  • Demo中的一些概念解析

完成一个迁移任务的主要流程

  1. project issues 页面(https://github.com/orgs/apache/projects/424/views/1) 选择未分配且未处理的 issue,并评论 “I will pick it” 来领取任务。
  2. 将 issue 状态修改为 InProgress,理解 issue 中命令功能并书写测试。
  3. 实现迁移任务代码,提交 PR 发起 review request,将 PR 链接附在 issue 中,并将其状态改为 In Review。
  4. 根据代码 review 意见修改代码并合并,将 issue 状态修改为 Done。

实现迁移任务的框架和原理

  • 旧优化器逻辑 主要分为三步:
    1. 使用 sql_parser.cup 文件解析语法: parseByLegacy()
    2. 校验语句合法性: analyze()
    3. 执行语句: handleXXXStmt(),位于 DdlExecutorStmtExecutor 里。
public class UnsetDefaultStorageVaultStmt extends DdlStmt implements NotFallbackInParser {

    public UnsetDefaultStorageVaultStmt() {}

    @Override
    public void analyze(Analyzer analyzer) throws UserException {
        if (Config.isNotCloudMode()) {
            throw new AnalysisException("Storage Vault is only supported for cloud mode");
        }
        if (!FeConstants.runningUnitTest) {
            // In legacy cloud mode, some s3 back-ended storage does need to use storage vault.
            if (!((CloudEnv) Env.getCurrentEnv()).getEnableStorageVault()) {
                throw new AnalysisException("Your cloud instance doesn't support storage vault");
            }
        }

        // check auth
        if (!Env.getCurrentEnv().getAccessManager().checkGlobalPriv(ConnectContext.get(), PrivPredicate.ADMIN)) {
            ErrorReport.reportAnalysisException(ErrorCode.ERR_SPECIFIC_ACCESS_DENIED_ERROR, "ADMIN");
        }

        super.analyze(analyzer);
    }

    @Override
    public String toSql() {
        final String stmt = "UNSET DEFAULT STORAGE VAULT";
        return stmt;
    }

}
  • 新优化器机制:尝试通过 executeByNereids 进行新优化器执行,失败则回退至旧优化器 executeByLegacy 执行。

  • 实现新任务:在对应命令的 run 函数中实现语法校验(validate())和执行逻辑。

实现一个迁移任务的原则

  • 保留旧优化器代码:避免大规模问题。
  • 避免旧优化器 Analyzer:不生成 xxxStmt 对象,消除对其依赖。
  • 参考旧逻辑:对比对应的 xxxStmt 逻辑。

如何书写迁移任务的测试

  • 迁移任务测试确认:确认可以用新优化器成功执行,参考 demo,并在 regression-test/suites/nereids_p0/ddl 下编写新测试。
  • 使用 checkNereidsExecute("sql") 进行脚本测试,验证 SQL 执行和优化器调用。

如何实现一个迁移任务

以下是结合 Demo(https://github.com/apache/doris/pull/43103) 的详细步骤解析:

  1. 书写案例

    • 分析迁移任务的目的和作用。
    • Demo 中 unset 任务,setunset 交替,确保设置生效。详细测试文件(https://github.com/apache/doris/pull/43103)
  2. 语法解析

    • 将命令转为抽象语法树,修改 DorisParser.g4,解析 UnsetVariableCommand
  3. 执行前检查

    • 实现合法性验证:在 UnsetVariableCommand.run() 中实现详细检查,可参考旧逻辑 UnsetVariableStatement.analyze()
  4. 实现执行逻辑

    • 参考旧优化器 handleXXXStatement,在 Demo 中使用 handleUnsetVariableStmt()
      老优化器
@Override
    public void analyze(Analyzer analyzer) throws UserException {
        if (Config.isNotCloudMode()) {
            throw new AnalysisException("Storage Vault is only supported for cloud mode");
        }
        if (!FeConstants.runningUnitTest) {
            // In legacy cloud mode, some s3 back-ended storage does need to use storage vault.
            if (!((CloudEnv) Env.getCurrentEnv()).getEnableStorageVault()) {
                throw new AnalysisException("Your cloud instance doesn't support storage vault");
            }
        }

新优化器

@Override
    public void run(ConnectContext ctx, StmtExecutor executor) throws Exception {
        if (Config.isNotCloudMode()) {
            throw new AnalysisException("Storage Vault is only supported for cloud mode");
        }
        if (!FeConstants.runningUnitTest) {
            // In legacy cloud mode, some s3 back-ended storage does need to use storage vault.
            if (!((CloudEnv) Env.getCurrentEnv()).getEnableStorageVault()) {
                throw new AnalysisException("Your cloud instance doesn't support storage vault");
            }
        }

        // check auth
        if (!Env.getCurrentEnv().getAccessManager().checkGlobalPriv(ConnectContext.get(), PrivPredicate.ADMIN)) {
            ErrorReport.reportAnalysisException(ErrorCode.ERR_SPECIFIC_ACCESS_DENIED_ERROR, "ADMIN");
        }

        ctx.getEnv().getStorageVaultMgr().unsetDefaultStorageVault();
    }

Demo中的一些概念解析

  1. Forward Trait:
  • 决定当前执行节点(Follower)是否需要与 Master 同步。

  • 重写 toRedirectStatus() 函数以确定同步策略。

  1. Global 模式:
  • 参数设置需要 forwardToMaster 操作。

  • Follower 向 Master 请求操作,Master 完成后写入 editLog,确认持久化后再完成操作。

  1. Session 模式或 Default 模式:
  • 无需同步,仅需在 Follower 的 Session 级别设置参数。

如果在操作中遇到问题或有深入讨论需求,欢迎通过附录中的邮件联系。


如需进一步了解或讨论,您可以在附录指定的项目链接和 Demo PR 中探索并贡献您的一份力量。这样,您便可以成为 Apache 顶级项目的贡献者之一,为开源社区做出重要贡献!

附录

  • Demo PR 示例(https://github.com/apache/doris/pull/43103)
  • Issues Project(https://github.com/orgs/apache/projects/424/views/1)
  • 维护者联系邮箱:lichi@selectdb.com、libinfeng@selectdb.com

关于社区

关于 Apache Doris 社区

Apache Doris 是一个基于 MPP 架构的高性能、实时的分析型数据库,以极易易用的特点被人们所熟知,仅需亚秒级响应时间即可返回海量数据下的查询结果,不仅可以支持高并发发点查询场景,也能支持高吞吐的复杂分析场景。

如果您对 Apache Doris 感兴趣,可以通过以下入口访问官方网站、社区论坛、GitHub 和 dev 邮件组:

非常欢迎您在社区论坛中与其他用户分享您的使用经验和技巧,或者向 dev 邮件组提交反馈和意见。

相信,您的参与将帮助 Apache Doris 变得更加完善。

![da](https://i-blog.csdnimg.cn/direct/e217f09f8c7543b0af2831241025071b.png)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

数据微光a

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值