“在开源社区中成长”——第十二届中国开源黑客松参与者真实感受

2021第十二届中国开源黑客松于5月28日在北京正式举行。举行地在丁章胡同的金融客咖啡,是一座古色古香的四合院,据说张作霖、张学良都曾把这里作为大元帅府和少帅府,也是溥仪办公和养老之地。

在个充满了故事的四合院里,我与Greenplum开源社区的小伙伴一起,在其他13个开源项目,超过15个开源社区的陪伴下,经历了两天的高强度的代码。这是我第一次参加可以自己上手的活动,感谢Greenplum中文社区给我提供的机会,不得不说收获很多。

从接触Greenplum以及其他开源软件后,我开始对开源软件的源代码产生了浓厚的兴趣,非常渴望了解软件如何能跑起来,如何能组成一个工程。在活动中,我们学会了如何使用GDB。在活动开始前,Greenplum原厂导师吕正华老师介绍说,学会了用GDB调试开源软件,任何开源软件都不再有”秘密”了。我用GDB的经验不多,唯一的经验就是在操作系统课程实验中用GDB+Qemu调试了linux内核启动过程。当时的我也只会跟踪一些代码,而不会调试以及找错,此次活动受益良多。

参加黑客松之前我还有点忐忑,担心自己的基础不够好。但从四合院门口进入会场的那一刻,我便深刻感觉到Greenplum社区真的非常友好。第一天上午是讲解部分,吕正华老师详细的讲解了相关理论知识和上手步骤。讲解过后便是实操环节。第一次参与真实的issue(GPDB issue #12061)的解决的我并不是很有头绪,想着从查询的运行开始。但由于查询是一个assert error,所以跟踪到assert之后就停止了,跟踪不到错误的位置,似乎断了线索。吕正华老师和张桓老师提醒我可以去根据assert错误条件然后去跟踪变量。每次跟踪没有线索之后,Greenplum的导师,以及社区的小伙伴们都很愿意帮助我。大家一起尝试跟踪变量,一起记住程序崩溃的位置,一起出谋划策跟踪。通过一个下午的努力,我们成功的定位了代码出错所在行,并且通过社区小伙伴们会后、晚上的努力,在第二天早上活动开始之前提交了Pull Request。

我和社区中的许多小伙伴一样,都是第一次参与开源项目,对于提交的流程和内容也说不上熟悉,在这种状况下,能够获得鼓励真的很开心。在Greenplum导师的带领下,我们成功完成了添加测试用例、完成测试、精简测试、并最终提交了PR。Greenplum社区的PR提出真的非常详细,从发现问题,分析问题,解决问题,加测试,整个PR提交非常工整有序。让我非常感动的是一个细节。由于社区中一部分小伙伴是第一次在项目中进行Pull Request,我们提的Pull Request格式上还是不太规范,但Greenplum社区回复的第一句话仍然是“感谢您对社区的贡献”。

除了自己上手的环节之外,在茶歇中还有不少开源社区进行演讲。从程序员、工程师角度看问题使我第一次感受到了开源软件的精彩。与之前一些介绍性的演讲不同,我可以听到更多算法层面、架构层面的东西,这些是难能可贵的。

这次黑客马拉松,对我来说,是学习,是考验,更重要的是,能够融入开源大家庭、Greenplum开源社区,能感受到互帮互助带来的快乐,在社区中成长。

——————

项目名称: Hacking Greenplum

任务目标

  1. 修复一个真实的Community Issue,成为Greenplum内核代码贡献者(commit message,test,comments,code review)
  2. 深入理解Greenplum的MPP架构,开发探索性特性,修改SQL建表语法,完整支持qd only table功能

完成情况

1、任务1

  • 全员都顺利搭建起来Greenplum开发环境
  • 顺利掌握用GDB定位诊断bug
  • 组员用开源工具SQLsmith发现buggy code
  • 组员投石问路,用注入代码并跑测试,锁定更简单复现办法
  • 组员提交commit完成pr
  • 任务一顺利完成

2、 任务2

  • 修改gram文件添加新语法distributed only_master;
  • 完成DML语句和join的支持
  • 任务二顺利探索

后续安排:

  • 任务一即将merge进Greenplum的master branch
  • 任务二是试验性,进一步在社区内沟通,测试性能和发掘用法,推进

贡献者以及贡献:

  • 1 PR
  • 2 commits
  • 代码百行++ —(但涉及诊断思考的过程,还是比较复杂的,也有了很多工具和技巧)
  • 特性1个
  • Bug修复1个
  • 项目者:参与全员用Greenplum的结对编程(pair programming)办法解决问题

作者简介

李想,目前就读于杭州电子科技大学卓越学院,计算机科学与技术专业2018级本科生。对开源MPP数据库感兴趣并积极参与在Greenplum开源社区之中。

关注微信公众号

VMware 中国研发中心