从小白到Apache项目Committer的成长之路。
开源项目没有那么遥远
前几天收到了Apache ServiceComb PMC的邀请邮件,这意味着我成为了一名Apache ServiceComb项目的Committer。喜悦之余,我想留下一篇博客作为自己工作的一个阶段性总结,同时也希望这篇文章能够给其他想要加入到开源社区的同学一点参考。
初次接触ServiceComb
最开始接触到“开源”的概念是在大学的计算机课程上,当时对于开源项目的印象就是:开源项目是由一群大牛程序员开发和维护的,作为小白的我只需要拿来用就好了。
毕业之后参加工作,我被分到了一个跟开源项目相关的工作组,需要向Apache ServiceComb项目提交代码。当时的心情真是既新奇又紧张,毕竟以前只是单纯地使用过开源软件,而现在自己终于要向开源软件项目提交代码了。这种能够在一个开源项目中提交自己代码的兴奋感,相信很多学软件专业的同学应该能够理解。但是自己又是刚开始工作的小白,担心自己写的代码太差了拿不出手,因此又紧张不已。而事实上我第一次提交代码的经过并没有预想中的那么多波折,作为一个开源小白,提上去的pull request有瑕疵是很正常的事情,根据检视者的意见修改好了就行——毕竟高手不一定高冷,社区的开发者们都是很热心的。
有了第一次提交PR的经历后,后面的工作就慢慢变得轻车熟路了。平常我在开源社区主要做的就是领一些新特性或者修复bug的issue处理,提交代码或文档的修改。
参与的方式不仅仅是写代码……
如前文所提到的,最初我参与Apache ServiceComb开源项目的内容是由工作驱动的。因为有一些新特性要完成,或者因为有一些bug要修复,所以我需要提交代码和更新相关文档。而在代码和文档之外的其他事务我并没有参与多少。
其实从我开始向ServiceComb提交代码时,我就订阅了Apache ServiceComb的邮件列表,也加入了Gitter聊天室。不过由于对自己的技术没什么自信,也受限于内向的性格,我在这些沟通渠道内长期保持着旁观的状态。当时的想法是,讨论ServiceComb设计和发展的事情我又参与不了,看看大佬们讨论就可以,到时候我再捞几个issue来做就好了。然而这种想法是不对的,对于我们自身在开源社区中的发展也没有好处。要参与开源社区的事务,仅仅只是埋头提交代码是不够的,积极参与社区的讨论、沟通,保持自己在社区中的活跃度,也是评判自己在社区工作好坏的一项标准。这也符合Apache之道中“社区胜于代码”的理念。此外,把将要进行的事情放到邮件中讨论,也是一个文档归档的过程。后续想要回溯某个特性为什么会被加进来,或者某个bug是如何触发的时候,搜索相关的邮件就可以了。如果有新的贡献者想要参与到社区开发工作中来,他们也可以通过查阅邮件来了解很多信息。这在无形中节省了很多后续的维护和沟通成本。
参与社区讨论的活跃程度也是评判一个开发者能否成为committer的重要标准。听先前已经进入ServiceComb社区的同事说,其实按照我的代码提交量来看,在之前我就可以成为committer了,然而由于我在社区沟通中的活跃度实在是太低了,所以才一直没有受到ServiceComb PMC的committer邀请……所以说,同学们一定不要被自己的腼腆性格坑了啊,要参与社区事务,就需要更积极地加入到讨论中来。
给有意者的一些建议
参与一个开源项目,对于自己阅读文档、分析源码、开发和沟通的能力都有很大的益处。这和开发一个业务系统是两种完全不同的体验,对于拓展个人的视野和经验很有帮助,我想大家应该从各种文章里了解很多了,我在这里就不多讲了 : )
如果想要参与到一个开源项目中,可以首先了解一下如何使用这个项目。给开源社区做贡献的方式不仅仅限于提交代码,修复文档问题可能是一个更好的切入点。通过阅读和修复文档问题,我们可以了解到一个项目的主要特性,这对于我们进一步了解项目源码也是很有帮助的。
同时,订阅邮件列表和使用Gitter也很有必要。通过这些,我们不仅可以了解到项目的最新动态,也能够参与到社区的讨论中来。如果还不了解如何发起一场讨论的话,可以先看看社区里的开发者是怎么做的,参与到其他人的邮件讨论中去。碰到其他的使用者提问也可以上去帮助解答,这同样是一种参与贡献的方式。上文已经提到过了,参与讨论沟通是社区活动的重要内容。不用感到不好意思,开源社区本身就是开放的,我们欢迎更多的人能够参与到项目的建设中来。
正所谓临渊羡鱼,不如退而结网。与其羡慕已经成功参与到开源项目中的同学,不如从现在开始行动,选择一个开源项目参与进去 ; )
文章的最后,我想向给与我帮助和鼓励的社区团队成员致以感谢,谢谢大家热心的帮助和指导,让我从一名小白成长为Apache committer。
ps:在这里小小地安利一下,Apache ServiceComb项目已经从Apache孵化器毕业,正式成为Apache顶级项目,这也是业界首个微服务项目在Apache孵化并毕业成为顶级项目。ServiceComb中包含的几个子项目都处于如火如荼的发展势头中,欢迎大家参与到ServiceComb社区建设中来~
本博客所有文章除特别声明外,均采用 CC BY-SA 3.0协议 。转载请注明出处!