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

ce53faff-35a2-4a3f-9c0e-f0a210b04101.jpg

了解更多Greenplum相关内容,欢迎访问Greenplum中文社区网站

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

ceebe35c-321c-480a-bb55-479cfe62d821.jpg

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

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

4ca8c58a-6b6c-49fb-b287-1e515f48919e.jpg

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

8960fd4a-5b73-4ea5-977a-8885c6ab66cf.jpg

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

fa8eea5a-7011-437e-b177-d65a89f41175.jpg

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

caf1f59d-87f3-43f7-8516-9751ef8cbc14.jpg

这次黑客马拉松,对我来说,是学习,是考验,更重要的是,能够融入开源大家庭、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)办法解决问题

7cbeaf7c-49ad-47d4-99e8-81025d59e52e.png

作者简介

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

up-f175fefbeb33b30075a094498c554b31130.png

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值