关于tdengine:从社区贡献者到加入核心团队开源给他带来了这些变化

8次阅读

共计 3148 个字符,预计需要花费 8 分钟才能阅读完成。

作者 | 尔悦
采访嘉宾 | 谭雪峰

就在往年六月份,又一位社区 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 那就阐明有成长了。

“我感觉开发者最好的状态就是把本人写的代码开源进去,帮忙他人的同时与开源我的项目一起成长。退出涛思数据后,我才是真正实现了这个‘最好’。”


✨想理解更多 TDengine 的具体细节,欢送大家在 GitHub 上查看相干源代码哦。✨

正文完
 0