速来报名!AICon北京站鸿蒙专场~ 了解详情
写点什么

为什么开源适合 LinkedIn

  • 2015-06-23
  • 本文字数:2413 字

    阅读完需:约 8 分钟

开源软件不再局限于解决小问题、底层问题,否则也不会有公司花代价去创建开源软件。如今,创建、部署开源软件的社区日渐成熟,他们代表着世界上最大的几个技术公司。为什么有此变化?为什么公司应该把一些精力花在开源软件上?为何要开源?

初衷就是开源软件能使你的工程师变得更强。随着他们的作品呈献给整个社区,他们的技艺也在精进。

他们能写出更好的软件

为别人工作,比起为自己公司工作,更能写出好软件,这听起来有点矛盾,但事实上却很有道理。当开发人员写一个“内部”软件的时候,他们倾向于在一些环节上偷工减料——我也是如此——尤其是在文档、代码的可读性和可重用性,以及编写完善的测试用例方面。但开源社区有多种选择,如果你的代码太晦涩,他们不会有耐心去搞明白它究竟在干什么。而公司内部则没得选。

在开源项目中,开发人员的名字会和他们创建的软件绑在一起,整个社区都在审视他们。这就好像给网上的代码和声誉配上一张面孔,每个人都能看到他们的设计取向和 bug。这大大激发了他们去完善自己的软件。开发人员都希望自己的名字和设计精良的美好事物联系在一起。

每个优秀的工程师永远在不停地学习,他们想跟上自己专业领域的发展步伐。直面那些自己公司之外的开发社区,能帮助他们看到最新的趋势,以及帮助他们学会如何利用社区带来的价值。而且,如果他们自己是一个开源项目的所有人,他们的“技术领导”技能也能得到长足的进步,因为他们必须要选择接受或拒绝来自社区的补丁。一个成功的项目,应该是贡献者齐聚,各种观点争鸣的社区。但不是所有的问题都有更简洁更好的技术解决方案的。他们必须决定选择什么,放弃什么,这很难,但在这种困难中,他们锻炼了新的技能。很多开源项目的留言板上充斥着偏激言论,口水战经常处于一触即发的边缘。

从公司的角度看,它能帮助打造“研发品牌”

研发品牌意味着一种公司特有的开发能力的烙印,就好像给产品贴个标签,上面写着“这是我们制造的”。打造这种品牌有很多方法。开源是一种很好的和其他开发者共享代码的方式。它可能无法完全揭示一个公司的内部运作机制,但肯定能展现出跟这个项目相关的各个方面。这也是资深员工给应聘者的一个展示窗口,一个企业向未来雇员发出的明确信号,即,如果他们来这儿工作,不仅能获得个人技能的提升,并且能充分利用那些他们喜欢的软件系统,而不用重新发明它们。

当然,在那么多支持的观点之外,也有一个反对的声音,那就是,开源并不适用于所有公司,也无法解决所有问题。

不要因为缺少人力而开源

在早期这是个常见的错误观点。这个观点的逻辑是,如果我有一个优秀的项目需要额外的帮助,那么开源它会吸引全世界的开发者为它做贡献。这是错误的,原因有二:如果项目成功了,它会从外部社区收到无数的需求,需要耗费额外的精力和时间把代码写出来,而这些需求很有可能跟公司创立这个项目的初衷相悖。如果项目没有成功,前期花了大量的资源去包装它就全部白费了。而且,要判断为项目写代码和提交补丁的个人或社区的能力好坏也很困难。毕竟在外部世界什么都有可能。要做出成功的开源项目,需要投入大量的时间来开发、监管和培育。

不要为了开源而开源

这个问题我通常称之为:“做个好公民”,多做做功课。在创立任何项目前,做个好公民,调查一下是否已经有社区在致力于开发类似的解决方案了。然后花点精力去评估一下,是否给已有的项目贡献代码会更好?通常,使用现有的项目并做出自己的贡献,价值远胜于重复发明轮子。

把糟糕的项目拿出去开源,会产生负面影响。人们审视这个项目后会疑惑,既然已经有了一个很棒的开源解决方案,为什么这个工程师或团队还要搞出这么一个水平低劣的东西来。这对于上面所说各种开源的好处,都是一种伤害。

如何创建成功的开源项目

这很不容易。老实说,LinkedIn 早期在这上面也是磕磕绊绊。我们早期学到的一个教训就是,开发团队不能为了开源,简单把代码丢给社区,然后就停止创新了。很多人认为只要一开源,社区会帮你带领这个项目继续前进,这种情况偶尔也会发生。但大多数情况下,你作为项目的缔造者,有责任保障它在开源的模式下继续发展好,并且你要尽可能多花时间在上面,就把它当作还是你公司内部的项目。

我们学到的另外一个教训是,多半的小型项目,应该集成到大型项目中去。LinkedIn 的第一批开源项目是一些小型的搜索组件,我们从自己基于“ Lucene ”项目的主搜索引擎之上创建了它们,但我们却没有和 Lucene 项目的开发者社区保持同步,大多数组件都没有集成到 Lucene 中,最终被丢弃——其实它们中的很多项目都很出色。Apache 社区则是一个极好的正面例子。单独的开源项目是不错,但是如果你能让这个项目抱上 Apache 这条大腿,那么请不要犹豫。一个成熟社区中的开发人员如果有激情去开创新的项目,成功率要高得多。

后来我们创建 Kafka 项目时,从过去所犯的错误中吸取了教训,明智地选择了投入资源,最终它成了我们的最佳开源项目。

最后,如果一个公司决定开源某个软件,他们必须要有心理准备,最后不得不跟这个项目分道扬镳。我第一次不得不给我的一个项目单独拉出分支的时候,感觉就像是杀死了自己的孩子。做出这个决定后,我整个周末都没睡好,感觉很惭愧……感觉自己像个叛徒。但是后来我明白了:一个项目一旦开源,它就有了自己的生命力。它很有可能演进成为一个你根本不想要的东西,并且不再和你的软件系统兼容。这一刻到来时,你别无选择,只能拉出分支单干了。这是一个自然现象,时不时会发生。你的孩子长大成人了,让大人重新过回他们自己的生活吧。

但这不应该把谁吓跑。开源是一件非常值得去做的事情,创建、管理、参与开源项目,其乐无穷。

查看英文原文: Why Open Source Works for LinkedIn


感谢郭蕾对本文的策划。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们,并与我们的编辑和其他读者朋友交流(欢迎加入 InfoQ 读者交流群)。

2015-06-23 00:312348
用户头像

发布了 77 篇内容, 共 36.6 次阅读, 收获喜欢 26 次。

关注

评论

发布
暂无评论
发现更多内容

ElasticSearch 低成本高可用最佳实践

冰心的小屋

elasticsearch 高可用性

子查询优化之 Semi-join 优化 | StoneDB 研发分享 #2

StoneDB

MySQL HTAP 数据库· StoneDB 12 月 PK 榜

升维数智化底座 迈向高质量发展

用友BIP

如何借助低代码开发平台 YonBuilder 填补应用开发 “产能缺口”?

YonBuilder低代码开发平台

开发者 低代码

AngularJS进阶(十三)JS利用正则表达式校验手机号

No Silver Bullet

正则表达式 AngularJS 12月月更

2022-12-02:有a块草莓蛋糕,有b块芝士蛋糕,两人轮流拿蛋糕, 每次不管是谁只能选择在草莓蛋糕和芝士蛋糕中拿一种, 拿的数量在1~m之间随意, 谁先拿完最后的蛋糕谁赢。 返回先手赢还是后手赢。

福大大架构师每日一题

算法 rust 福大大

实时渲染正在改变可视化游戏

3DCAT实时渲染

云计算 云服务器 云算力 渲染引擎 渲染

Fuzzing(模糊测试)的前世今生(下)

云起无垠

网络安全 漏洞挖掘 Fuzzing 模糊测试

HIFIVE音加加 × 火山引擎:正版曲库+智能视频创作SDK,短视频全链路需求一站式解决!

HIFIVE音加加

短视频 火山引擎 HIFIVE音加加 视频配乐 版权音乐

如何快速构建研发效能度量的指标体系?

Kyligence

数据分析 指标

技术分享 | 将覆盖反馈融入黑盒模糊测试技术提升测试效率

云起无垠

让对外合作更高效,就用WeLink跨企业沟通

路过的憨憨

焱融全闪系列科普| 为什么 SSD 需要 NVMe?

焱融科技

云计算 高性能 nvme 文件存储 全闪存储

排查Linux恶意进程

灵霄

守护安全|AIRIOT城市天然气综合管理解决方案

AIRIOT

物联网 天然气

如何选择正确的哈希算法?

Jackpop

云原生中的标准化

穿过生命散发芬芳

云原生 12月月更

Fuzzing(模糊测试)的前世今生(上)

云起无垠

如何远程Debug内网(或者防火墙后)的Java服务

石臻臻的杂货铺

Java debug 后端

AngularJS进阶(十)AngularJS改变元素显示状态

No Silver Bullet

AngularJS 12月月更 元素状态

AngularJS进阶(十一)AngularJS实现表格数据的编辑,更新和删除

No Silver Bullet

表格 AngularJS 12月月更

直播 | 数据仓库?数据湖?停止纠结,流批融合的极速 Lakehouse来了!

StarRocks

#数据库

华为云数据库GaussDB(for Influx)揭秘:数据分级存储

路过的憨憨

面对当下最热的多模态,为什么这些业界和学界专家说“不必追热点”

小红书技术REDtech

Proxyless Mesh 在 Dubbo 中的实践

阿里巴巴中间件

阿里云 云原生 dubbo

Fuzzing(模糊测试)的前世今生(中)

云起无垠

【愚公系列】2022年12月 微信小程序-Component组件

愚公搬代码

12月月更

建筑中如何使用3D可视化?

3DCAT实时渲染

云计算 3D可视化 智慧建筑 BIM

数字化改变了什么?WeLink在实践中给出答案

路过的憨憨

Fuzzing(模糊测试)技术,你真的了解吗?

云起无垠

观测云产品更新|应用性能新增服务清单功能;用户访问监测 Session 查看器调整;事件新增移动端跳转选项等

观测云

可观测性 观测云

为什么开源适合LinkedIn_语言 & 开发_曹知渊_InfoQ精选文章