开工福利|免费学 2200+ 精品线上课,企业成员人人可得! 了解详情
写点什么

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:002188
用户头像

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

关注

评论

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

一对一语音视频聊天APP系统开发玩法设计/步骤指南/案例源码

V\TG【ch3nguang】

数据安全审计必备攻略:一文掌握6大核心审计要点(附下载)

极盾科技

快手主站前端工程化探索:Gundam 脚手架在新春除夕项目中的实践与展望

快手技术

前段

零成本搭建个人 APP 和小程序后台

北桥苏

php Python 运维‘ Vercel railway

观测云的安全监控策略:Prometheus 生态的深度集成

可观测技术

Prometheus

推三返一消费全返模式系统开发指南教程/步骤详细/功能逻辑/源码程序

V\TG【ch3nguang】

IPQ5018 motherboard: QCN6102-QCN6122 Multi-band integration -DIY customization

wifi6-yiyi

wifi ipq5018 WIFI6E

成本效益分析:观测云投资的回报

可观测技术

成本优化

让程序员欲罢不能的职场工具合集

伤感汤姆布利柏

解锁未来财富密码:AI自动化副业创收班——终身财富加速器

测吧(北京)科技有限公司

测试

2024年最受欢迎的轻量级项目管理软件推荐

爱吃小舅的鱼

项目管理 轻量项目管理

创新驱动:观测云如何帮助企业在竞争中保持领先

可观测技术

数据分析

基于飞桨框架实现PCA的人脸识别算法

百度Geek说

人脸识别 百度飞桨

火山引擎携手领克汽车与英特尔,发起首届AI创造者大赛

新消费日报

AIGC应用实战营-毕业总结

王琨琨

云手机如何保障TikTok多账号安全运营

Ogcloud

云手机 海外云手机 tiktok云手机 手机群控 tiktok矩阵

PYUSD跃升为第六大稳定币:借势Solana和高APY的成功之道

区块链软件开发推广运营

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

ReidsTemplate序列化器

李爽

一文了解电商大促系统的高可用保障思路-献给技术伙伴们

京东科技开发者

七牛云 CDN 视频瘦身,为视频分发「减负增效」

七牛云

CDN CDN带宽

DOGS空投掀起交易所竞争热潮,TON生态能否再次引爆市场?

区块链软件开发推广运营

区块链开发 链游开发 NFT开发 公链开发 dapp项目开发

得物App白屏优化系列|网络篇

得物技术

android 企业号2024年8月PK榜

未来展望:观测云技术的发展与企业业务的融合

可观测技术

业务监控

5款在线PPT工具,一键生成精美的PPT幻灯片!

职场工具箱

效率工具 职场 PPT 办公软件 AI生成PPT

Java 流式编程的七个必学技巧

高端章鱼哥

微软发布 Phi-3.5 系列模型,涵盖端侧、多模态、MOE;字节 Seed-ASR:自动识别多语言丨 RTE 开发者日报

声网

短剧开发丨短剧系统开发模式讲解丨短剧现成源码

V\TG【ch3nguang】

短剧系统开发

安全可靠的国产自研数据库PolarDB V2.0,让数据库开发像“搭积木”一样简单!

阿里云数据库开源

动态化-鸿蒙跨端方案介绍

京东科技开发者

为什么要用云手机进行海外社交营销

Ogcloud

云手机 海外云手机 云手机海外版 海外社媒营销

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