Apple 核心系统高级工程师 Asta 谢(谢孟军)就《开源如何影响程序员》这一主题,结合自身经历、从开源中得到的自我提升,详细阐述了自己对开源的理解,如何在国内做开源,并成为 GitHub 上 Go 语言领域中国排名第一,以及如何同国内外开源者一起参与开源的过程。

本篇主要讲诉我做开源经历的一些事及关于开源的影响。

我的开源成长之路

我在 Github 上做的一些事

做开源做了好多年。目前的状况是:在 github 所有的 user 里面,全球排名 16。go 语言领域里面,中国排名第一。世界排名第六,前五位排名均为组织。在 Github(github.com/astaxie)上,我分享了一本书, 一个 beego,一些工具。希望写一本书。目前在准备一个秘密项目,之后会开源出来。同时也参与了一些其他的开源组织。刚刚说的 TiDB 的开源,也会去改一下代码,贡献一下么。贡献是一个享受的过程。

始于大二的开源生涯

最早做开源,是从大二接触世界上最好的语言 PHP 着手的。那时候接触了 PHP3、fleaphp。一直在研究这些东西。机缘巧合的情况下,认识的库比较多一些,库积累的多了,就开始用一些框架。那时候,国内有一个框架,叫 fleaphp。与此同时,我参与到了 fleaphp 框架组里面。

同样用之前提到的方式,如果你要参与一个项目,首先,你就要去用它。大学给别人做兼职做好多个网站。基本都是用 fleaphp 做的。所以对 fleaphp 几个源码级别的东西,已经掌握的非常熟练了,也知道哪一些方面可以改进,哪一方面做的不是很好。参与开源先使用,拼命的用它,到崩溃为止。只有把它用到崩溃为止,你才能找到他痛点在哪里。

我做开源 fleaphp 框架时,好像没有 github,基本上我们就是通过一些 qq 群直接交流。哪一块代码不对,要修改一下,然后直接修改了。那时代码还是托管在 Google 的 code 上,协作也通过它。之后基于此做了很多视频教程,写了很多热门教程。fleaphp 应该怎么去用?现在用的比较多的是 thinkphp。其实 thinkphp 刚开始的时候,抄袭了我们很多的理念。然后,当年 fleaphp,我们没有继续做下去,也是因为我们几个创始人开源方向不一样,我去了 go 领域,离开 php 界。

这里想分享大家的是,开源是谁主导并不重要,重要的是,你要怎么参与进去。就参与的过程,我给作者提供了一个 PR。然后那个作者把 PR 给 Merge 进去了,然后成了 Contributor,已经贡献进去了。我觉得我的思路和作者的思路,其实是一样的,都是在思考修改一个问题,都是为了改进一个东西。

当然,好的作者的话。比如说,你提供一个 PR, 过去有时候,人家会拒绝你。在整个交流过程中,其实,也是可以学到很多东西的。有时候,他为什么会拒绝这个东西?Code Review 的时候,为什么会是这个样子?我觉得,这才是开源社区的一个氛围。只有参与进去了,你才能学到更多的东西。

再之后,做过一些边边角角的东西,比如写教程、做视频教程。再后来,才去思考做一些工具类,怎么样用一个脚本语言快速去生成一个我要的东西(基于 fleaphp 的),例如自动化生成结构。这些思想会影响我自己做 beego,很多的东西其实都是自动化。怎么样自动化也是有历史渊源的。我以前做过这个东西,我知道这个的好处,可以生成我想要的东西。自动化都是为了节省我们的时间嘛。

为了让代码自动化,做工具类的尝试

代码自动化可以让我们有更多的时间做更多的事情。这个思想,促进了我做 beego。文档和工具都是写 beego 的时候,脑子里立马生成的东西。如果我没有参与到 fleaphp 这整个开源过程的话,我不可能说,在做 beego 的时候,是一步而就的。所以说,所有的经历,就像乔布斯在斯坦福做毕业典礼的时候说的,人生是有各个点串起来的。你之前做某件事的时候,是不经意做的,但是你后面做另一件事的时候,其实你前面已经做了很多的铺垫。也就说人生的经验累积到一定的步骤,你就会爆发。所以这也就是一个由量变到质变的过程。

那这之后呢,我就去了盛大云,做 CDN 的开发。那个时候,也只是做一些管理系统(用 PHP 的)。那个时候,认识了老徐,开始接触一些 go 语言的东西。那个时候,go 语言是 R60 版本,还没有正式的 release 版本之前。就开始尝试写一些 go 语言的东西。为了尝试用 go 语言去写呢,因为 php 确实折磨了我好长一段时间。

特别是我加入盛大珈学院之前,我在百事通也是用 php 做我们自己的 TBIB 系统,遇到很多的性能问题。我记得有次熬通宵熬了两个通宵。为了把那个并发从 300 提高到 400,整个熬了两个通宵。但是大家想,从 300 到 400,性能呢没有提升多少,但是你就花了好长时间做这个。每一个小细节都需要花心思去优化。

后来,接触了 go 语言之后,就感觉,随便一写都是 php 的好几倍。当然,现在 php7 出来之后,也是性能提升了好多。那是你相比于 go 语言,go 语言毕竟是静态语言,性能还是天生的比较好。就开始接触了 go 语言,就开始写我们自己的应用大文件分发系统、调度系统,然后短域名啊,就发现 go 语言写起来就有一个非常好的好处:就是我只要编译过后(前提逻辑通畅),跑到线上,性能非常好。

所以那个时候就开始深入的学习 go 语言起来。那个时候,我们组里还有一个小伙子李辉,他是做 C++ 的么,会了解到很多底层的东西。所以很多底层的东西,我会和他交流,在交流当中就开始不断的学习。也是那个时候,自己每天回家就利用业余的时间,不断地把我自己学习 go 语言的整个过程来全部写下来。然后,才有了这个《goWeb 编程》这本书。其实,写了很长时间的。我估计,那个时候,是第一本有关于 go 语言的第一本书。应该肯定是。

被编辑一句话打动,写了一本书

这本开源之后呢,大家反馈比较好。然后,出版社就开始联系我,问我要不要出版?我的理念是,开源嘛,知识是要共享的,是要帮助到其他人的。因为,我刚刚和大家说过,我在做 fleaphp 的时候,做过以及写过很多的教程,教大家怎么去学习。在写这个《goWeb 编程》的时候,也是怀着一份让大家怎么样更好学习 go 语言的心事编写的。

当出版社来找我的时候,我就感觉,我又不赚钱,我为什么要出版。然后,我被一句话打动了。他说,其实有些人是热爱看书的,看书也是知识传播的一种渠道。我想了想,也对。确实有些人是这样的。上厕所的时候,可能就是喜欢看书。在不同的场景下,有需求在么,多一个渠道,何乐而不为呢?然后就答应了他们,但是说实在的,出版很复杂。要审稿,审计。要各种英文字正规范。就不符合我这闲惯了的心。

在写这本的时候,也是在盛大做了好几个下午。把那些基础的组件抽取出来之后,在写书的过程中,在最后两章,我就思考着,给大家介绍下,怎么教大家写出一个框架来。所以,才有了 beego 框架的原型。在写 beego 之前,我用的是 python 的 Tornado。所以 beego 的最初版本就是 Tornado 的 go 实现。大家现在还可以看到保留了那个风格。

我觉得 control 里面对应的就是(莱斯特 for)的 post,get 方法。那后面的就是逐步地增加才有了现在的很多的模块。当然了,今天我也是打算做 beego 的 2.0 版本。也是经过这么多年,也是积累了一些很多用户的需求吧。也是打算直接来一个 2.0 版本吧。

开源对技术人的影响

影响一:眼界

我们自己在写这个东西的时候,就是为了给自己解决事情的。当你把他开源出去,你的眼界就会开拓很多。你想我的用户群里面,其实他们有各种的需求。这各种各样的需求哪里来呢?很多情况下,我自己都没有想到,他们还没有这么用。然后,我们机会可以一起来改进它。这就是开源社区。他们能够让我看得到,我在工作当中遇不到的问题。让我的眼界放的更阔。设计的时候,项目就可以更 flexible。特别是,像我以前写的时候,就会犹豫导出还是不导出,都无所谓么。

但是,现在很多时候,我都不大敢导出,因为导出的时候,用户用了,就会很麻烦。现在就实现最小化导出。思考思考再思考。一旦要导出,就会思考 2 遍,到底需不需要导出,因为后面再撤掉,影响就会比较大。

第二个眼界,就是你把这个项目,放到 github 上面。那 github 上,有全世界各个地方的人。你会接触到各种各样的人,90% 的人都是很 nice 的人。他们也很愿意和你交流,愿意得到我们的帮助。或者说,他们的需求是什么样子的。我觉得他们各种各样的信息,对我来说都是一个输入吧。这里面各种各样的信息,对我也是一个很好地学习方式。

影响二:心态

做开源的时候,刚开始就是从一个年轻小伙子,年轻气盛。和别人对喷,到后来无所谓。其实,是越来越享受这个开源的过程了。而不是愿意花时间和别人对喷。人家去骂你的时候,你可以欣然接受。ok。也无所谓。你觉得心情不好就骂几句。实际上,你就讲道理的和别人讲。如果说那个人是在没办法讲道理讲得通。ok. 那我们就没必要理睬这样的人就好了。这个也不是你的用户群,对吧。你也不应该把你的时间浪费在这些人身上,应该把你的时间花在喜欢你的人以及你的开源项目的人身上。服务好他们,这才是我们应该真正做的事。

影响三:个人提升

这是最多的方面。例如,我写出来的代码是不是很好,高质量的代码。当然是尽量好一点。没有说,我一写出来的,就是非常完美的。很多时候,你就回看发现,半年前的代码,怎么会这么烂呢。因为你个人是在不断提升,很多时候,他开源代码都是会选择做出接近完美的代码,才会公开。这个也是个人的平衡,就是说做完美了才公布呢,还是小步快跑呢?我个人喜欢小步快跑,赶快实现原型。然后持续的去改进他。因为我想知道,当用户用了之后,这个东西是不是他们想用的东西。

影响四:沟通能力

你需要去写文档们需要去 github 回复,需要去 qq 群、微信群里去沟通交流。那怎么样,很好的去和用户沟通交流,把你自己的信息直接通过最短的时间传递你最明确的意思。其实这是非常锻炼人的。到底,怎么样一个好信息?怎么样一个直接传达的方式,这是非常锻炼一个人沟通能力的。

影响五:team work 团队精神

你单兵作战,是可以做一个好项目。但是你持续要有一个团队是很有必要的。像 beego,有很多人可以维护的,像小黑同学,余双棋同学,有一个貌似意大利的很牛的。只有你很积极地参与进来,我才会认可你,才会把你纳为 contributor,才会是团队的人。那团队的人要怎么样一起工作,怎么样相互的 review,怎么样把代码做好,怎么样去完善它,协调好各方面。

转载于:https://my.oschina.net/u/3293685/blog/850662

开源如何影响程序员 如何在国内做开源相关推荐

  1. 关于开源的思考 开源如何影响程序员?

    Apple 核心系统高级工程师 Asta 谢(谢孟军)就<开源如何影响程序员>这一主题,结合自身经历.从开源中得到的自我提升,详细阐述了自己对开源的理解,如何在国内做开源,并成为 GitH ...

  2. 开源浪潮下程序员的职业规划和成长

    无论从年初开源社发布的<2020 中国开源年度报告>还是整体的大环境,不难看到中国的开源正在崛起,越来越多的来自中国的开源项目和开发者们正在走入大家的视野.在开源浪潮的大趋势下,程序员又该 ...

  3. Copilot逐字复制代码,恐抹去整个开源社区?程序员拿出律师证发起集体诉讼

    选自GitHub Copi­lot inves­ti­ga­tion 作者:Matthew Butterick 机器之心编译 视学算法发布 编辑:蛋酱.张倩 Copilot是开源社区的「寄生虫」? 作 ...

  4. 今夜科技谈 | AlphaCode 会不会影响程序员的饭碗?

    我们希望 AI 能越来越聪明,但又害怕它们过于聪明. AlphaCode:超半数程序员的自主编程 AI 2 月 2 日,DeepMind 在官方博客中,介绍了他们最新的研发成果 AlphaCode. ...

  5. 影响程序员生涯的三个错误观念,你千万不要犯

    转载自   影响程序员生涯的三个错误观念,你千万不要犯 程序员在社会上,到底是怎样一个生活群体?是否能找到自己方向?其实,路一直都在那里,只是你看不到而已! 当初的你,可能一直被一些技术牵着鼻子走,并 ...

  6. NanShan开源即时通讯团队讨论程序员空闲期可以做的事

    原文:NanShan开源即时通讯团队讨论程序员空闲期可以做的事 NanShan开源即时通讯 团队讨论程序员空闲期可以做的事,这里列出以下几点: 空闲期指项目全面进入测试阶段或者一个项目完结.另一个未曾 ...

  7. 学历影响程序员的工资吗?

    近年来,我国互联网飞速发展,外卖.电商.短视频等各类产品层出不穷,互联网模式不断创新.线上线下服务融合加速以及公共服务线上化步伐加快. 其中,推动我国互联网飞速发展,网民规模持续增长离不开一批中国程序 ...

  8. php程序员必会的,PHP程序员必会的PHP开源工具

    在Web开发世界里,PHP是最流行的语言之一.一些非常好用的PHP开源工具着实拯救了不少开发任务繁重的PHP开发人员,减轻他们的开发负担.好的开发工具富有特点而且能够帮助开发者快速高效地编辑程序,它是 ...

  9. 写给那些想做程序员和不想做程序员的人

    <写给那些想做程序员和不想做程序员的人> 首先说一说进入计算机专业的目的,我个人是因为十分喜欢IT业,很喜欢折腾电脑,所以在填报志愿是毫不犹豫的在报了的所有的学校都填写的计算机专业,梦想着 ...

最新文章

  1. 美专家:中国的机器人优势所引发的忧虑
  2. Python---进阶---logging---logger
  3. NullInjectorError:No provider for MyNewService
  4. SAP Fiori RouteMatched and getById
  5. BZOJ4503 两个串 【fft】
  6. ElasticSearch核心基础之索引管理
  7. 学生管理系统的几个设计模式
  8. 手机python 3.8解释器_不看后悔!Python 3.8 新功能大揭秘
  9. 8款最佳照片PDF比较软件推荐[2020指南]
  10. 关闭文件和打印机共享服务器,网络发现自动关闭、无法启用文件和打印共享的解决办法...
  11. 计算机应用基础综合测试题b卷,10级《计算机应用基础》期末试卷B卷
  12. Duplicate zip entry
  13. Shopee卖家如何布局产品合理定价,新手必知的定价策略
  14. VIVADO软件介绍与使用
  15. 【SAP】ABAP开发——ALV展示后字段的下划线连接
  16. ArcGIS Pro 3.0学习版安装教程
  17. 区块链编程语言_区块链解决方案开发的编程语言
  18. Unity基础—Transform类
  19. 【数据结构与算法】——第二章:线性表
  20. clickhouse副本和分片

热门文章

  1. 一个有趣的numpy题目------不同包里面的重名函数
  2. php 根据时间获取二十四节气,返回json
  3. PHPer的月工作总结之构建抽奖工具
  4. 利用电表SOC芯片RN7211低成本实现三路高精度24位AD采集(带PGA功能)
  5. 常用波特率计数查找表
  6. 自动驾驶之车位线检测(opencv,c++)
  7. 五年级上册计算机教学工作计划,五年级信息技术上册教学工作计划
  8. 将十六进制转化为十进制
  9. Software Testing - 如何测试一部电梯
  10. 从零点一开始机器学习之Win10 64位下安装Cuda+Cudnn