写点什么

InnerSource: 来自 PayPal 内部的开源实践

  • 2015-11-04
  • 本文字数:1409 字

    阅读完需:约 5 分钟

InnerSource 仅仅是一个名称,它是一种在企业内部应用开源软件实践的软件开发方法。来自 PayPal 的技术带头人 Cedric Williams,在开源大会OSCON 上解释了在PayPal 如何使用InnerSource 来打破孤岛、加强合作、增加生产力。

实践开始于18 个月以前,清算平台的团队当时大概需要花2/3 的时间来重写由区域团队所提交的代码。而区域团队,有一个很重要的职责,那就是确保PayPal 能够在不同国家符合当地的一些规定。这种情况对于谁都没有益处。清算团队没法做好自己的本职工作,而区域团队所话费时间写的大量代码而别人又用不上。

PayPal 从开放源代码软件中汲取了灵感,尤其是来自 Apache 软件基金会的实践。他们发现了开源软件的组织原则,即每个项目都有各个金字塔的层:用户,在最底层;贡献者;可信任的提交者;最上层是架构师/开发者的领导者。PayPal 评估了这些个情况后,作出最大的变化是引入“可信任的提交者”角色。

找到合适的可信任的提交者可不是一个简单的决定:清算团队中只有 10% 的人是这样的角色。Williams 在此回答了人们一个问题,成为可信任的提交者需要哪些技术技能?首先必须有深厚的技术功底,然后对于代码库的核心了如指掌,即使有了这两样也不能成为最出色的。可信任的提交者还必需拥有良好的人际交往能力,他们要成为教练员。他们需要以积极、清晰的方式来沟通。举例来说,不要说“这些代码无法接受”,而是需要这么去说“这是我需要你去做的方可接受你的代码,这里有几点原因[…]”。

不出所料,引入可信任提交者角色带来了政治上的扯皮风险,所以不得不小心的去处理,无论是清算团队内部还是外部。为了使全局能够接受变化,可信任提交者不仅仅要审核来自区域团队所提交的代码,还要审核来自清算团队其他成员所提交的代码。

实施 6 个月之后效果出来了,清算团队再也没有花时间去重写别人的代码了,而仅仅花了 10% 的时间去做审核代码的工作,该团队进行了一次大规模的重构,且在没有做任何计划的情况下提升了 4 倍的性能。团队成员的心态也从排斥转变为积极的接受。一个最大的副产品是所有相关的沟通都通过写作来完成,多数是在 Github 上:PayPal 使用 Github 来托管他们的开源软件,使用企业版 Github 来托管他们的闭源项目。这使得能够在所有的团队之间进行知识共享和传播。

在 InnerSource 之前,PayPal 尝过不同的方法,它们是:自顶向下的强制和驻场。

第一种方法,即自顶向下,是比较传统和古老的了。定义严格的规则和利益相关者,自顶向下,让人们承担责任。这无法解决问题,但是可以产生很多的会议。

驻场的情况会好一点。来自各个区域团队的高级工程师们都被租借到圣荷西,和开发团队的成员们在一起工作。驻场能够达到知识的共享,且能够对彼此团队的行为有所了解。非常遗憾的是 ,一旦这些工程师们回到了各自的区域团队之后,他们就会成为瓶颈。他们发现找不到时间或者是没有所需要的技能将他们所学到的传授给他人。

Williams 为 InnerSource 的入门者提供了一些建议。在第一步,在你的工程师团队中将可信任提交者限制在 10%,要求所有的代码都须公开审核,且要确保代码的审核要聚焦于完成什么从而使代码更加的良好;第二,要求所有的对话都是成熟的、得到尊重的;第三,分享你的经验。PayPal 将于 11 月 9 号在加利福尼亚的圣荷西举办首届 InnerSource 峰会。PayPal 还为此赞助了一本小,目标读者是哪些想进一步学习此方法的人们。

查看英文原文: InnerSource:Internal Open Source at Paypal

2015-11-04 18:002099
用户头像

发布了 30 篇内容, 共 11.0 次阅读, 收获喜欢 0 次。

关注

评论

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

企业如何对多个IT系统快速管理?谁能告诉一下!

行云管家

IT运维 安全运维 运维管理

工赋开发者社区 | 数字化转型的两大关键点:转什么 ,如何转?

工赋开发者社区

使用虚拟合成数据训练对象检测模型

3D建模设计

人工智能 机器学习 合成数据

理论+应用,带你了解数据库资源池

华为云开发者联盟

数据库 后端 华为云 华为云开发者联盟 数据池

英特尔与阿里巴巴深化合作,以软硬件创新全方位加速“芯经济”发展

E科讯

【宝藏工具】开源组件信息一键查询,快速获取组件来源、版本、漏洞补丁、推荐版本!

网安云

喜讯!INFINI Easysearch 在墨天轮数据库排名中挺进前30!

极限实验室

数据库 easysearch 极限科技 数据库排名 搜索型数据库

PlistEdit Pro for Mac(Plist编辑器) 1.9.7直装激活版

mac

苹果mac Windows软件 PlistEdit Pro Plist文件编辑软件

大模型训练中Loss出现NaN的解决策略

百度开发者中心

大模型训练 大模型 LLM

大模型在金融监管科技中的应用价值

百度开发者中心

人工智能 大模型 LLM模型

BES 在大规模向量数据库场景的探索和实践

Baidu AICLOUD

elasticsearch 向量检索 大模型

JProfiler 14 for Mac(Java开发分析工具)永久激活版

iMac小白

JProfiler 14激活版 JProfiler 14下载 JProfiler 14 mac

mac应用音量控制软件Sound Control for Mac激活版

iMac小白

sound control下载 sound control mac sound control激活版

中文最新Infuse 激活安装包7.6.2

胖墩儿不胖y

Mac软件 多媒体播放器

通过Python脚本支持OC代码重构实践(二):数据项提供模块接入数据通路的代码生成

百度Geek说

Python 重构 脚本 企业号10月PK榜

CorelDRAW 2023 完美激活版下载

iMac小白

CorelDRAW 2023下载 CorelDRAW 2023破解版

Tower for Mac(Git客户端) v10.1.1注册激活版

iMac小白

Tower下载 Tower破解版 Tower mac

15种稳定扩散模型的技术示例

3D建模设计

Stable Diffusion 稳定扩散 自动纹理工具

Transformer与预训练语言模型的探索

百度开发者中心

人工智能 大模型 LLM

钱包开发:区块链钱包热钱包​加密货币开发公司集成服务

区块链软件开发推广运营

交易所开发 dapp开发 区块链开发 链游开发 NFT开发

Mac虚拟定位软件:AnyGo for Mac激活版

iMac小白

AnyGo下载 AnyGo激活版 AnyGo中文版

软件测试/测试开发丨利用ChatGPT 生成自动化测试脚本

测试人

软件测试

云资源信息安全就用行云管家!

行云管家

云计算 云安全 云资源

利用LLM大模型和智能问答BI实现智能报表生成

百度开发者中心

人工智能 数据可视化 大模型 LLM

网站加速神器:国外服务器让你的网页飞起来

一只扑棱蛾子

国外服务器

使用稳定扩散和SAM修改图像内容

3D建模设计

AI纹理 稳定扩散

摄影后期图像编辑推荐 Lightroom Classic 2023 中文激活

mac大玩家j

Mac软件 图像处理工具 图像编辑处理

InnerSource:来自PayPal内部的开源实践_开源_João Miranda_InfoQ精选文章