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

沃尔玛尝到了推行 InnerSource 的甜头

  • 2016-08-04
  • 本文字数:1929 字

    阅读完需:约 6 分钟

自从 CTO Jeremy King 上台后,沃尔玛对开发团队按 InnerSource 的方式进行了重新整合。经过磨合期,大家已经认可了这种新的开发方式,而且 InnerSource 带来的各种好处开始不断显现出来。最近,Clint Boulton 对沃尔玛采用 InnerSource 的情况进行了进一步报道

InnerSource 仅仅是一个名称, 它是一种在企业内部应用开源软件实践的软件开发方法,也叫 Enterprise Source 或 Internal Open Source。InnerSource 实际上就是在公司内部,在各个不同开发团队之间以开源方式开发软件的工作方法。它可以带来的好处包括更快提交项目、团队之间合作更顺畅、自主创新、高质量的代码和文档等。已经有许多大公司在内部实施了 InnerSource,包括 Autodesk、BLoomberg、Bosch、Capital One、 PayPal 和 SanDisk 等。InnerSource 对于那些有着上千人规模开发团队的公司尤为重要。

身为沃尔玛 CTO 和 WalmartLabs 负责人,Jeremy King 认为:

我们对这种内部开源的模式实践得越多,我们的组织就越有弹性,我们也就能越快地将代码上线为用户所用。
建议你们也采用开源软件和开发方式,因为这样可以开发更快、成本更低和质量更好,但我们也希望你们也能为开源做出贡献,因为这样对整个社区是有好处的。

沃尔玛实施 InnerSource 采用的是企业版 GitHub,用法和免费公开版大致相同,唯一的关键不同是它是部署在企业内部、外部不可访问的,因为有一些关键算法还是不能公开的。

自从 King 从 2011 年由 eBay 跳槽过来之后,沃尔玛就加速了对开源的推进。King 说他们已经把许多传统软件换成了开源产品,比如 Cassandra 之类的 NoSQL,还用 Kafka 替换了消息总线。也引入了许多开源开发工具,如 Node.js 和服务器端 JavaScript 环境等,并用 OpenStack 重构了它的电子商务平台。

沃尔玛的研发团队有一千多人,他们每个月要做约 30000 次代码部署,但是 King 仍认为他们只是“世界上最大的创业团队”而已,因为有的公司做一个项目可能就会要上千人了。沃尔玛的一千多名研发工程师分布在约 100 个小组中,每个小组有 10-20 人,开发、构建、测试和部署等全部由小组自行负责,以 DevOps 模式工作。尽管大家的工作模式都是持续集成、迭代开发,不可避免地有时候某些团队会由于任务过多而成为瓶颈,这样在小组之间可以共享、开发和贡献代码就非常重要,可以在某种程度上避免这样的“单点故障”了。King 举例道,比如某个工程师需要能连接到支付网关上,但负责支付网关的团队手上已经堆积了 5 个更重要的项目了,没时间做这个。在这种情况下这个工程师可以自己把相关功能实现了,然后再请支付网关团队的人审核通过,就可以了。或者比如说一个支付团队的工程师对于购物车等功能忽然有了什么新想法,那他就直接简单的作出原型来,然后通过 GitHub 提交给对应团队就好了。

当然 King 也提到了一些困难,InnerSource 并不是完美地适合每一个项目的。要能成功地跨团队提交代码的话,你就必须对对方项目的代码框架和逻辑等也熟悉,这是一个大门槛。

King 说沃尔玛推行开源的开发方式之后,对开源社区成果的使用和回馈行为还帮助他们吸引了许多技术人才。在他们准备录用的候选人中,50% 手中还握有 Google、Apple、Facebook、LindedIn 或其他硅谷著名公司的 Offer,可是最终这些人中有 70% 还是选择了沃尔玛。King 把争夺人才胜利的原因归功于两点:一是小而专的团队,二是开源。“大家都对我们已经取得的成就非常赞赏,同时也希望如同在创业公司工作一样。”

在大数据概念引爆流行产业界之前,沃尔玛已经开始了网站数据库整合迁移和Hadoop 集群扩展工作,收购Kosmix 并在其基础上建立Walmart Labs,并在近年着手收购专注于数据挖掘或移动社交的初创公司如OneOps、Inkiru,Tasty Labs,OneRiot,进军互联网。

沃尔玛于今年早期发布了开源项目OneOps,这是一个让程序员们可以测试各家不同公司的云平台,并在它们之间自由切换的平台,它的功能对于使用了多种异构云模型的公司非常有好处。OneOps 可以在任何基于云的平台上,在整个生命周期内,帮助用户管理关键的应用程序负载,同时可以让用户从一家云供应商迁移应用、数据库或整个云环境,到另一个云供应商,以便争取更好的报价。OneOps 强大的云技术,可以帮助工程避免被限制一个云供应商上。OneOps 的开源,对于把应用程序部署在云、需要持续管理和监控的技术人员来说,绝对是个好消息。同样,这对想要更换云服务商的公司也是喜闻乐见的。

最近沃尔玛又发布了新的开源项目 Electrode ,使用反应式开源组件的程序员们可以用它轻松地为移动 Web 和 App 开发页面。


感谢李建盛对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-08-04 19:002203
用户头像

发布了 152 篇内容, 共 71.2 次阅读, 收获喜欢 64 次。

关注

评论

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

恭喜天翼云“翼起飞”战队在CCF国际AIOps挑战赛中夺得亚军!

天翼云开发者社区

测试管理和领导力秘诀,12+ BAT 大厂测试经理的干货经验汇总

霍格沃兹测试开发学社

接口测试实战 | Android 高版本无法抓取 HTTPS,怎么办?

霍格沃兹测试开发学社

安全可信 | 首批!天翼云通过可信云安全云工作负载保护平台评估

天翼云开发者社区

技术分享 | 一文带你了解测试流程的体系

霍格沃兹测试开发学社

代码层走进“百万级”分布式ID设计

得物技术

数据库 缓存 分布式 性能优化 企业号九月金秋榜

加快云网融合发展,打通算力传输大动脉!

天翼云开发者社区

多线程原理和常用方法以及Thread和Runnable的区别

共饮一杯无

多线程 8月月更

用GaussDB(for Redis)存画像,推荐业务轻松降本60%

科技怪咖

教育信息化迈入2.0时代,呆猫云工作站破除技术壁垒

神奇视野

【CSPO认证】国际Scrum联盟认证导师CST授课 | 全国招生

ShineScrum

CSPO认证

快应用与原生APP相比,都有哪些优势?

Speedoooo

小程序 移动开发 轻应用 快应用 移动框架

DeFi+NFT质押置换挖矿系统开发技术方案详情

开发微hkkf5566

技术分享 | 软件测试入门必会-流程管理平台

霍格沃兹测试开发学社

OpenHarmony技术挑战课题征集

OpenHarmony开发者

OpenHarmony

测试面试 | Python 算法与数据结构面试题系列二(附答案)

霍格沃兹测试开发学社

华为伙伴暨开发者大会之GaussDB高校行,产教融合持续赋能人才培养

科技怪咖

测试开发基础 | Python 算法与数据结构面试题系列一(附答案)

霍格沃兹测试开发学社

GaussDB(for Cassandra)新特性发布:Lucene二级索引,让复杂查询更智能

科技怪咖

MobTech 短信验证使用说明与应用创建

MobTech袤博科技

App sdk 短信验证

测试面试 | 某 BAT 大厂测试开发面试真题与重点解析

霍格沃兹测试开发学社

《低代码发展白皮书(2022年)》&《2022低代码·无代码应用案例汇编》,发布了

华为云开发者联盟

云计算 后端 低代码 开发

“云”上交通,“翼”路畅行

天翼云开发者社区

呆猫云工作站助力Omniverse云上部署试水元宇宙

神奇视野

【CSM认证】9月17-18&24-25日在线周末班 | 全国招生

ShineScrum

CSM

软件测试 | 测试开发 | 接口自动化测试中如何对xml 格式做断言验证?

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

接口自动化测试

看完这篇你将get VR/AR沉浸式技术的“创作密码”,速来!

神奇视野

技术分享 | 做为测试,那些必须掌握的测试技术体系

霍格沃兹测试开发学社

软件测试 | 测试开发 | 接口自动化测试之JSON Schema模式改如何使用?

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

JSON Schema

驭数有道,天翼云TeleDB系列产品全新升级

天翼云开发者社区

测试面试 | 一道大厂算法面试真题,你能答上来吗?(附答案)

霍格沃兹测试开发学社

沃尔玛尝到了推行InnerSource的甜头_GitHub_足下_InfoQ精选文章