作者 | 尔悦
采访嘉宾 | 谭雪峰
就在今年六月份,又一位社区 Contributor 成功入职涛思数据,他的身份也从 TDengine 的社区贡献者转变为专职的研发人员。在身份变换的同时,他对于自身的成长和发展、对于代码的品质和要求、对于开源的理解和融入都有了一个新的认知和提升。
“你是怎么看待开源的?你觉得开源能带来什么?
如何才能成为一名优秀的 Contributor?
参与开源项目,成为 Contributor 后可以获得什么?
......
带着这些问题,看看他眼中的答案是否和你所见略同。
选择成为逆流而上的“逆行者”
作为大连人的谭雪峰,从小到大基本都生活在大连这座海滨城市,大学毕业后,基于自身兴趣出发便在家附近找了一份研发工作,如果没有成为 TDengine GitHub 开源社区的贡献者,或许他的生活和工作轨迹也不会这么快从大连转移到首都北京。在众多年轻人“逃离北上广”的大潮中,谭雪峰成为从家乡到北京逆流而上的“逆行者”之一。
从一个熟悉的城市转移到另一个陌生的城市,这其实是一件说起来容易但做起来并不简单的事情,在这之前,95 年出生的谭雪峰可以说已经在大连扎根了 26 年,贸然间从故土抽身总会产生一些不适和纠结,但谭雪峰却并没有给自己太多的思考时间,他很快就接下了涛思数据投来的橄榄枝。
“虽然一直呆在大连是离家近了,工作生活会更加安逸平静,亲戚朋友之间也能有个照应,但对于研发行业来说还是北京的大环境更好。”在“苟且生活”和“诗和远方”里谭雪峰一个都没选,他选择了“未来和成长”,这是一条攀登的路,但是无疑将会看到更好的风景。
事实上,谭雪峰并非科班出身,他喜欢研究逆向和安全,凭借着自身的热爱他开始自学编程,毕业之后顺理成章成为了一位研发工程师。谭雪峰直言,刚开始工作时因为自己基础打的不够牢固,在工作推进时困难重重,但他并没有因此退缩,通过汲取书本上的专业知识以及参与 GitHub 上的一些开源项目,来丰富自己的专业理论和实战技能,同时这种学习方式也为他结识 TDengine 埋下了伏笔。
“此前我是在工业物联网行业,对各种时序数据库都了解一些,以便于更好地开展工作。国产的时序数据库还是比较少的,其中能做到开源的就更少了,因此我一直都比较关注开源,在这些开源数据库里面,TDengine 的性能是非常高的,当时就想将它引入到平台系统中,这样一来二去就和涛思的人认识了。”
那谭雪峰为什么会加入到涛思数据?这其中还发生了哪些故事?
业内人都知道,涛思数据有很多学历背景强大、专业能力突出的研发工程师,他们有的来自国内外知名大学,有的是研究生、博士生,还有一些人拥有大厂研发背景,整体团队实力非常强劲。作为一个非科班出身的工程师,谭雪凭借着什么得到了涛思数据的青睐?
与涛思数据结缘,从开源开始
“我现在在涛思数据主要负责 TDengine 的应用研发和周边生态建设工作,说起来加入涛思数据的始末,除了工作上的合作加深彼此了解外,也和关注开源这件事有很直接的关系。”
据谭雪峰回忆,刚开始接触涛思数据其实还是因为自身工作的原因,为了完成开发任务了解了 TDengine 的源码,并为了能让其在 Windows 上使用通过 GCC 编译做了一些修改,他也因此成为 TDengine 的贡献者之一。
因为谭雪峰一直通过学习开源的代码来提升能力,从反哺精神出发也就想做一些事情来回馈开源社区。 正好这时涛思数据举办了一场开源比赛——做 TDengine 和 HiveMQ 的对接,作为 Contributor 的谭雪峰略经思考便进行了报名,还取得了一个不错的结果。“这是我第一次参加开源社区活动,展示自己的同时还能够回馈社区,也正是通过这次活动让我更加深入地了解了涛思数据,萌生了想要加入的想法。”
进入涛思数据后的谭雪峰并没有给自己太多的适应时间,就立刻投入到工作中,他将整个 Go 连接器进行了重构,在此过程中对 CGO 有了更多地了解,但不可避免也遇到了一些问题。
“遇到比较大的问题是 CGO 的调优上面,如果 C 的方法阻塞的话会独占线程,这样一来并发性就会显著降低,当时为了解决这个性能问题我看了不少的文章,但是相关调优方法也比较少。之后在 Go 的 GitHub 开源社区上发掘了一些可以借鉴的经验,最后综合了几个渠道获取到的方案一一做 benchmark 并选了其中比较优的进行业务尝试。”
在涛思数据工作的过程中,谭雪峰深刻感受到了如涛思这类纯技术驱动的企业技术和产品管理上的正规性, 对于功能的探讨、代码的提交、review 以及质量的管理都有着非常严格的要求。由于基础软件的 bug 和性能瓶颈会直接影响所有上层应用,因此研发会更注重单元测试和 benchmark。
谈及到未来发展方向,谭雪峰表示还是要投身到开源项目中,从其中学习的同时贡献自己的力量推动项目发展。“目前我的工作是在为 TDengine 做周边应用,其代码也都已经开源在 Github(https://github.com/taosdata/TDengine)上了,欢迎大家关注。”
开源帮助谭雪峰找到了一个前进的实现自我价值的方向。那么对于开源,谭雪峰又有哪些深刻理解呢?对于 Contributor 的成长,他又有哪些不一样的建议呢?
Contributor 三要素:敢写、开源精神、社区意识
“我认为开源是一种发展趋势,项目在开源之后会得到各个方面的反馈,使用者发现不合理的地方会提交 issue,继而社区用户会认领 issue 提交自己的修改,使用者、开发团队和社区用户三个角色共同丰富项目内容、推动项目发展,这是一个良性循环的过程。”
在谈到开源的价值时,谭雪峰觉得闭门造车式的项目开发势必没有开放开源力量大、速度快,俗话说众人拾柴火焰高,开源的项目成为众多开发者学习观摩的对象,反过来,开发者们也愿意用自己所学去扶持项目前进。
对于谭雪峰来说,他所维护的 TDengine 就是一款非常吸引开发者的开源项目,“TDengine 本身的高性能就让人眼前一亮,作为后端开发者对于性能的追求是没有止境的。”同时他认为社区维护者对于反馈的处理态度也是衡量一个开源项目优质与否的重要指标,谭雪峰回忆,在他第一次给 TDengine 提交 pr 的时候,就有专门的人联系上他进行验证和指导修改,最直观的感受就是这个社区是活的,自己提的 pr 是有价值的。
谈及如何成为一名优秀的 Contributor,谭雪峰认为主要在于三点。 “首先是要有开源精神,参与开源就像是一个爱好一样,愿意为之付出时间和努力,再就是要敢写,提交 issue 或 pr 之后共同开发者会和你讨论提交的代码是否是合理,格式和性能是否满足,这个过程也会逐渐提高能力。最后是要有社区意识,Contributor 的头衔除了给我们个人带来荣誉外,更重要的是带来一份责任感,要发自内心地回馈社区。”
而且成为 Contributor 之后,开发者会更加注重代码的质量,因为这不再是只在自己的一方小世界里创造,目的仅仅是为了“跑起来”,不需要注重格式和质量,也不必太过于上心性能和调优。在开源世界里有很多人都会看到你的代码,社区将成为一种正向的鞭策力量。
说到自己的成长之道,谭雪峰也有一番深刻见解。“在我们进入社会之后,大部分时刻都是要靠自觉去学习和提升技能,如果在工作中缺乏自信,感觉安排下来的工作都非常困难,就更应该多看多写,不光要写代码还要把优化的过程写出来,最简单的办法就是写完一段代码之后隔半个月再去看,如果觉得当时自己写的非常 low 那就说明有成长了。”
“我觉得开发者最好的状态就是把自己写的代码开源出来,帮助别人的同时与开源项目一起成长。加入涛思数据后,我才是真正实现了这个‘最好’。”