AICon 深圳站 Keynote 嘉宾官宣!共探AI价值转化的实践路径 了解详情
写点什么

沃尔玛尝到了推行 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:002493
用户头像

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

关注

评论

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

喜大普奔 | FinClip Hackathon 2022 结果宣布, Top3 项目出炉!

FinClip

What? 从小程序反向生成App?!

FinClip

【直播回顾】OpenHarmony知识赋能第五期第五课——多媒体子系统之视频解读

OpenHarmony开发者

OpenHarmony 多媒体

代码重构,真的只有复杂化一条路吗?

华为云开发者联盟

代码 代码重构 过度设计 代码设计

520,解锁开发者的专属浪漫

葡萄城技术团队

情人节 520

使用 jMeter 对需要 User Authentication 的 Restful API 进行并发负载测试

汪子熙

Java Jmeter 性能测试 SAP 5月月更

数据分析软件有哪些分类?

清林情报分析师

数据分析 数据可视化 知识图谱 分析软件 分析工具

FinClip 前端之 VUE 核心原理总结

FinClip

31点经验分享与吐槽

老白鹿

作为软件工程师,给年轻时的自己的建议(上)

禅道项目管理

程序员 工程师 职业成长

【小知识】云管理平台与一般管理系统有什么区别?

行云管家

云计算 云管理平台 云管理

JavaScript类型转换

源字节1号

飞书、钉钉和企微的三巨头之争下,其他厂商在移动平台赛道如何奋起直追?

BeeWorks

比渗透测试更有用,红队演练该如何开展?

青藤云安全

如何在 Web 应用里消费 SAP Leonardo 的机器学习 API

汪子熙

机器学习 前端开发 前端框架 SAP 5月月更

Niobe开发板:基于OpenHarmony操作系统进行多线程(多任务)开发

拓维信息

OpenHarmony

盲盒APP开发的六大功能模式基础设置

WDL22119

盲盒商城 盲盒 盲盒开发 盲盒小程序开发 小程序开发

Google Guava中EventBus使用不当会导致什么故障?

BUG侦探

kafka Guava EventBus

FinClip SaaS 版上线啦

FinClip

年薪80W,在大厂呆了10年的我,被裁得心服口服

博文视点Broadview

Seata 企业版正式开放公测

阿里巴巴云原生

阿里云 开源 云原生 seata

许北林:我为什么加入OpenHarmony生态?又为什么要做“启航KP”开发套件?

OpenHarmony开发者

OpenHarmony 开发者故事

这知识点真细,Python获取HTTP响应头和响应体

梦想橡皮擦

5月月更

thinkphp 中 fetch 方法怎么用

CRMEB

520,用Python定制你的《本草纲目女孩》

华为云开发者联盟

Python 华为云 modelarts 本草纲目女孩 MoXing

业务逻辑的灵魂在哪里?

清林情报分析师

数据分析 数据建模 数据可视化 分析软件 分析思维

2022年广州市等保测评公司新排名看这里!

行云管家

网络安全 等保 等保测评 广州 等保测评公司

架构实战营 第 6 期 模块六课后作业

火钳刘明

#架构实战营 「架构实战营」

涛思数据与中天钢铁签署战略合作协议,加速钢铁行业的数字化发展

TDengine

数据库 tdengine

AI简报-Image Colorization调研

AIWeker

深度学习 5月月更 AI简报 Image Colorization

大数据培训在 Presto 中使用哈希改善动态集群缓存命中率

@零度

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