微软打造了全球最大的Git代码库
丹棱君有话说:今年 2 月,微软宣布将用 Git 管理 Windows 源代码。随后,Visual Studio 宣布开发 “Git 虚拟文件系统(GVFS)”,并将在终极项目和超大型团队中推行 Git 。5 月,Windows 开发团队基本完成 GVFS 部署,超过 3500 多名工程师开始使用。截止 5 月 24 日,系统收到了 25 万多次的 Git 提交,平均每天推送代码 8421 次,接受合并请求 2500 次。微软已经将 GVFS 开源,并邀请其他感兴趣的公司来使用,并加入贡献行列。GVFS 是如何管理超大规模数据的?系统的性能在最初的版本基础之上做了怎样的改进和优化?数千名 Windows 工程师对 Git / GVFS 真实评价如何?今天,丹棱君为大家“请来” Visual Studio 公司副总裁 Brain Harry 先生,讲一讲我软打造的全球最大 Git 代码库的来龙去脉,掌声有请~
今年 2 月,微软出人意料地宣布,将用 Git 管理 Windows 的源代码。
当月,我撰文宣布将在终极项目和超大型团队中推行 Git,并为此开发了 “Git 虚拟文件系统”(简称 GVFS) 。GVFS 和一系列 Git 增强功能通过虚拟 .git 文件夹和工作目录让 Git 能管理好超大型代码库。开发者可以只下载自己需要的那部分,而无需下载整个库、提取所有文件。
那时候,GVFS 仍是一个构想,处于实验阶段,尚未经实践检验。我们验证了几个大型代码库,但未在一定量级的工程师团队中推广,所以有的只有成功的信念。现在,我们终于有了实质性证据。
除了和大家分享我们的成果,我们还要宣布之后的 GVFS 工作计划,包括进一步开源、接受代码贡献以及为微软及其合作伙伴和客户进行系统改进和功能优化。
Windows 已登陆 Gi
Windows 登录 Git 的前三个月,我们基本完成了 Windows 开发团队的 Git / GVFS 部署。
首先来回顾一下,Windows 的代码共有 350 万份文件,如果全部 checkout 到 Git,生成的代码库将近 300 GB 。此外,由 4000 多位工程师组成的 Windows 开发团队每天在 440 个分支上生成 1760 个“实验室版本”和成千上万的合并请求验证版本。文件数量、代码仓库大小和工程活动,每一个都是不小的挑战,更何况这些因素是叠加在一起的。因此,确保开发者的工作效率是摆在我们面前的巨大难题。在迁移到 Git 前,我们在 Source Depot 上创建了 40 多个代码库,并利用工具进行管理。
今年 2 月,我们把所有代码都放在一个版本库中,供数百位工程师使用,每天生成小于 10% 的每日构建。从那时起,我们开始分阶段在整个 Windows 开发团队中推行 Git 部署。
第一次,也是最大的一次飞跃,发生在今年 3 月 22 日,我们开始在拥有 2000 位工程师的 Windows OneCore 团队部署 Git 。星期五,这些工程师还在 Source Depot 上工作,过完周末,星期一回来就要面对基于 Git 的全新体验。整个周末,我的团队提心吊胆,祈祷工程师星期一还能正常工作,以免将一腔怒火发泄到我们头上。事实上,Windows 开发团队为防止意外发生做了充分备案。很幸运,所有备案都没有启动。
坦率地说,第一天系统运作正常,工程师们的工作也进展顺利,这让我颇为惊讶。当然,我们也碰到了问题。例如,因为团队规模和工作性质的关系,Windows 经常需要跨分支进行超大型合并(10000 次修改中有 1000 次冲突)。第一周我们就发现负责合并请求和解决合并冲突的 UI 界面根本无法支持如此巨大的数据量。为了让 UI 正常显示,我们不得不虚拟化列表并逐步抓取数据。几天时间后,这个问题得到了解决。整体而言,那一周大家的反馈超出了我们的预期。
为了了解 Git 的部署是否成功,我们对开发团队进行了“满意度”的调研,同时也挖掘了其他信息。部署两周后,第一次调研结果出来了:
我不会为这些数字欣喜若狂,Windows 团队刚经历翻天覆地的变化,他们必须学习全新的工作方式,这个转变过程本身就是一项巨大工程,能给出这样的评价和反馈,我已经相当满意了。尽管 2000 多位受访人员只给了我们 251 份反馈,但这就是调研的现实情况。
除了调研,我们还通过观察“工程活动”,也就是工程师们是否能顺利完成工作,来判断 Git 的部署成功与否。例如,我们测算了正式分支的“签入”数量,当时,有一半团队还在用 Source Depot,有一半已经迁移到 Git,于是我们观测了两个平台的正式分支的“签入”数量。从下图可以看到 Source Depot 上的签入数出现大幅下降,而 Git 上的合并请求数激增。总体而言,两者的总和保持恒定。我们认为这些数据说明系统运行正常,不存在大的阻碍。
今年 4 月 22 日,我们迎来了 1000 多位工程师新用户。今年 5 月 12 日,又有三、四百位工程师加入我们。每个阶段我们都经历了相似的进展模式,现在已有 3500 多位 Windows 工程师在 Git 上工作。其他团队正在忙于他们目前的交付任务,还在寻找迁移的最佳时机。
在这个规模上,系统运行得非常棒。 给大家看一组数字:
Windows 登录 Git 的前三个月,代码库收到超过 25 万次 Git 提交。
平均每天推送代码 8421 次。
6600 审阅者接受合并请求: 平均 2500 次 / 工作日。
活跃公开分支:4352 个。
完整编译版本:1760 个 / 天。
这个超大代码库里正发生着海量活动。
GVFS 的大规模性
满意度调研也收到了负面反馈,背后的原因有:比如,一些人无法安装 Git 、一些人对学习新知识和接受新事物感到抗拒,但最重要的还是性能问题,我想就此多说几句。 Git 推广时,很多性能还未完善。我们针对 Git 运行的关键性能指数进行检测,以下是日志系统收集的 3500 多位工程师使用 GVFS 的数据。
表格中的“目标”值,是系统正常运行需达到的最低值,低于这个值时,系统运行会变慢,甚至无法使用。我们也可以看到,过去 7 天 80% 的结果和前 7 天的差值对比,数据说明系统正变得越来越慢,我将在下文解释这一点。
先说一下背景,用原生的 Git (“vanilla Git”)实现 ,很多命令耗时 30 分钟或几个小时,有些甚至永远无法执行。相较于此,如果大部分命令在 20 秒内完成,就已经是一个巨大的进步。但是对于用户来说,每次运行命令都需要等待 10 - 15 秒,仍然是非常糟糕的体验。
第一次推广的结果,成为我们的主要收获之一。如果你曾读过我介绍 GVFS 的博文,就会了解我们在 Git 和 GVFS 里做的许多工作,是让系统的运行量是和被读取的文件数成正比,而非代码库里的文件数。 当工程师们不断抓取代码库,触及更多内容时,会导致 “over hydration” 的问题。 简单来说,那些被读取但未使用或是被修改的文件会日益堆积,导致系统性能降低。虽然,工程师可以自己“清理”,但操作麻烦,少有人做,所以系统变得越来越慢。
基于此,我们进行了性能提升,称之为 “O(modified)”。改善后,可以使许多关键命令的执行成本与修改过的文件数成正比(也就是前文提到的未提交的编辑) 。 目前,虽没有相关结果的统计数据,但早期试点用户的反馈良好,我们将向整个团队做推广。
我从上文中的表格挑选了几个例子,将性能结果复制到 “O(hydrated)” 列,另增了一个 O (modified)列,结果来自经过 O(modified)优化的同样的命令。所有的数值都以秒为单位。正如你看到的,性能全方面得到提升—— 有些很微小,但有些高达两倍,甚至接近五倍。这些提升很可能改变大家对性能的观感。我并非志得意满(除非测试结果降至一秒以内),但这已是非常大的进步了。
另一个关键性能改善体现在分布式研发方面。Windows 的开发团队分散在全世界各地 —— 美国、欧洲、中东、印度、中国等。横跨超远距离、在非理想的网络带宽上拉取海量数据是个巨大问题。为此,我们为 GVFS 开发了一个 Git 代理服务,可以在用户端缓存 Git 数据。为避免在高峰负载时段影响终端用户的体验,我们降低了 Visual Studio Team Service 主服务中的一些会占用大量带宽的服务,例如 Build Server 。我们在世界各地共有 20 个 Git 代理,目前已并入 Team Foundation Server Proxy 。
下面我将举例说明它的作用。这个 Windows Team Services 帐户位于美国西海岸的 Azure 数据中心。从图表中可看出,对于一个 Windows 工程师,80% 的 Clone 操作需要 127 秒完成。由于绝大部分 Windows 工程师都在雷德蒙工作,所以这个数字代表了他们的体验。我们曾在北卡罗来纳州办公室做过测试,那里不仅距离远而且网络带宽低很多。如果不设置代理,在北卡罗来纳州进行一次 Clone 则需要近 25 分钟。配置、更新代理后,Clone 只花了 70 秒(比雷德蒙团队还要快,因为他们没有使用代理,需要通过数百公里的互联网才能达到 Azure 数据中心)。从近 25 分钟到 70 秒,相当于提升了 95% 。当 GVFS 访问“故障”文件时,我们也看到类似的改进。
由此可见,共用 Git 与 GVFS 完全适用于超大规模代码库,而且结果证明工程师能有效工作。在提升工程师们的满意度方面,我们仍然有许多工作要做,接下来推广 O(modified)将是重要一步。
快来试试 GVFS 吧
如果想尝试 GVFS,你只需从 https://github.com/Microsoft/GVFS 下载、安装,创建一个 Visual Studio Team Services 帐户和一个 Git 版本库即可。 GVFS 发布至今,进展很多,关键改进如下:
定期更新已发布的代码库 —— 转向“面向社区开放式的开发(development in the open)”。目前所有的最新修改(包括新的 O (modified))都会发布到公共代码库,并将定期更新。
发布 GVFS 之时,我们还未做好接受外部代码贡献的准备。现在,我们的基础架构都已到位,热烈欢迎大家和我们一起改进 GVFS 。
GVFS 依赖于我们称之为 GVFlt 的 Windows 文件系统驱动程序。之前发布的这个驱动程序还没有做任何的数字签名。 自然,大家在试用过程中会碰到问题。5 月 24 日,我们发布了一个基本消除问题的签名版本,例如,大家在安装前无需禁用 BitLocker 。尽管有了一个签名版的 GVFlt 驱动,但这只是一个临时的方案。预计细节问题处理完毕之后,此项功能会被并入今后的 Windows 版本。
从讨论 Git Merge 开始,我们就在更广泛的 Git 社区探讨 Git 和 GVFS 的扩展问题。我们和其他面临类似难题的大型科技公司(如 Google 和 Facebook)进行了交流,分享经验和解决方案。同时,我们与主流 Git 客户端工具厂商达成合作,确保 GVFS 的顺利使用,包括:
Atlassian SourceTree —— SourceTree 是第一个使用 GVFS 进行验证的工具,并已发布了更新版本。
Tower —— Tower Git 团队正在打造下一个 Windows 版应用,并将支持 GVFS 。不久大家就可以在 https://www.git-tower.com/windows 下载到支持 GVFS 的免费更新。
Visual Studio —— 当然,如果我们自己集成 Git 的 Visual Studio 能支持 GVFS 。六月初推出的预览版的 VS 2017.3 已加入 GVFS 。
Git for Windows - 作为我们扩展 Git 的部分工作,我们还为 Git for Windows 贡献了代码(Git 命令行),包括支持 GVFS 。现在,我们还有一个 Git for Windows 的专有派生,但随着时间的推移,我们将把所有修改贡献回主线。
总结
我们正将微软其他大型研发团队的代码库部署到 Git 上。取得的进展有:
Windows 登录 Git 的前三个月,已有 3500 多位 Windows 开发工程师开始使用 Git 。
部分性能得到显著提升,推出 Git 代理 。
以最新代码更新了多个开源项目,并邀请社区贡献代码。
推出签名版的 GVFlt 驱动程序方便大家试用。
社区合作,开始在主流的工具像 SourceTree,Tower,Visual Studio 内加入对 GVFS 的支持。
在 https://www.visualstudio.com/learn/git-at-scale 发布了多篇详解 Git 和 GVFS 扩展的技术文章。
这场微软内部激动人心的转变,对我的团队和 Windows 开发团队来说,都是一个极富挑战的项目。我为所取得的进展感到高兴,也非常愿意倾听大家对我们未来工作的建议。如果你也需要使用大型代码库,而希望迁移到 Git 上,我会推荐你试试 GVFS 。现在,Visual Studio Team Services 是唯一支持 GVFS 协议增强功能的后端实现。如果我们收到足够多的需求,会在未来的 Team Foundation Server 中加入相应的支持,其他第三方的 Git 服务提供商也是我们愿意合作的对象。
微软打造了全球最大的Git代码库的更多相关文章
- 使用git checkout 指定git代码库上的指定分支
因为曾经一直是在用svn,到狼厂,大家都用Git. 哥的开发环境:IntelliJ 说说简单的操作过程吧. 1.检出Git代码库 cd到指定文件夹 git clone http://..../andr ...
- git代码库误操作还原记录
先做一些前情提要: 我们项目使用git作为代码管理,同时为了操作更方便,安装了乌龟git(tortoiseGit)工具.以下几乎所有操作都是在乌龟git上进行. 我们的项目是分阶段完成的,在完成上一阶 ...
- 针对远程Git代码库使用SSH公匙
→ 运行Git Bash→ 创建SSH公匙和私匙ssh-keygen -t rsa→ 输入SSH公匙存放文件,选择使用默认的,按Enter→ 如果已经存在,提示是否重写,输入n,按Enter→ 打开C ...
- git代码库的使用
代码库/使用指南 http://learn.zone.jd.com/cmsuser/index.htm 在win7系统下使用TortoiseGit(乌龟git)简单操作Git@OSC http://m ...
- centos7.2下编译安装&&使用-git代码库
centos7.2下编译安装git Git简介 Git是一个分布式版本控制系统 Git vs SVN SVN是典型的集中式版本控制起,版本库集中存放在服务器,当我们用自己的电脑干活儿的时候,需要先从中 ...
- 克隆您的Git代码库和添加源文件
内容正在建设中 标签:Bitbucket
- 15分钟学会使用Git和远程代码库
git是个了不起但却复杂的源代码管理系统.它能支持复杂的任务,却因此经常被认为太过复杂而不适用于简单的日常工作.让我们诚实一记吧:Git是复杂的,我们不要装作它不是.但我仍然会试图教会你用(我的)基本 ...
- 使用Git和远程代码库
git是个了不起但却复杂的源代码管理系统.它能支持复杂的任务,却因此经常被认为太过复杂而不适用于简单的日常工作.让我们诚实一记吧:Git是复杂的,我们不要装作它不是.但我仍然会试图教会你用(我的)基本 ...
- git 删除本地分支和远程分支、本地代码回滚和远程代码库回滚
[git 删除本地分支] git branch -D br [git 删除远程分支] git push origin :br (origin 后面有空格) git代码库回滚: 指的是将代码库某分支退 ...
随机推荐
- SRAM SROM DRAM DROM DDR NAND FLASH EMMC的区别
RAM(Random Access Memory)的全名为随机存取记忆体,它相当于PC机上的移动存储,用来存储和保存数据的.它在任何 时候都可以读写,RAM通常是作为操作系统或其他正在运行程序的临时存 ...
- React库protypes属性
Prop 验证 随着应用不断变大,保证组件被正确使用变得非常有用.为此我们引入propTypes.React.PropTypes 提供很多验证器 (validator) 来验证传入数据的有效性.当向 ...
- <c和指针>学习笔记1之快速上手和基本概念
1 c语言中的注释 功能:使这段代码在程序中不起作用,当然如果是功能注释,那是方便其他人阅读您的代码. 大部分情况下,多行的注释,我们采用的是这种方式,例如 /*内容*/. 这个符号不能嵌套,也就是 ...
- Working Experience - NLog 多实例时配置文件冲突
正文 问题: 当前项目已使用 NLog 的情况下再引用使用 NLog 的项目, 出现配置文件冲突, 有一个配置文件不工作 方法: 使用 LogFactory 代替 LogManager 来获取 Log ...
- 洛谷P1654 产品排序(sort)
P1654 产品排序(sort) 题目描述 有一系列产品,给定每个产品的加工时间和冷却成型时间(冷却过程产品之间没有关系,是单独冷却的).现在你手上有两台机器可以用来加工,你需要安排产品加工的顺序以及 ...
- codevs 3342绿色通道
3342 绿色通道 时间限制: 1 s 空间限制: 256000 KB 题目等级 : 黄金 Gold
- 【VueJS】sublime text3支持VueJS语法高亮显示插件vue-syntax-highlight
1. sublime text3支持VueJS语法高亮显示插件vue-syntax-highlightgithub地址: https://github.com/vuejs/vue-syntax-hig ...
- 在linux服务器下日志提取的python脚本(实现输入开始时间和结束时间打包该时间段内的文件)
1.需求:近期在提取linux服务器下的日志文件时总是需要人工去找某个时间段内的日志文件,很是枯燥乏味,于是乎,我就想着用python结合linux指令来写一个日志提取的脚本,于是就有了以下脚本文件: ...
- Codeforces Round 56-B. Letters Rearranging(思维)
time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...
- element-ui关于form表单在dialog中的重置
form表单的重置是以第一次打开的数据作为重置标准,如果先打开的是更新,那么重置之后以第一次更新的数据作为标准; Dialog 中的内容是懒加载的,目前 edit (更新)方法的写法导致 Form 刚 ...