Git 2.18版本现已支持Git协议v2
极客时间编辑部
讲述:杜力大小:1.23M时长:02:41
最近,Git 的核心团队成员布兰登 - 威廉姆斯(Brandon Williams)宣布,在最新的官方 Git 客户端正式版 2.18 中,添加了对 Git wire 协议 v2 的支持,并引入了一些性能与 UI 改进的新特性。
在几周之前,Git 协议 v2 刚刚合并到 Git 的 master 主干分支。Git wire 协议定义了 Git 客户端与服务端如何对于 clone、fetch 和 push 等操作进行通信。
据了解,新版本协议的目标是提升性能,并使其能够更好的适应未来的改进。
另外,新协议的主要驱动力是使 Git 服务端能够对各种 ref(分支与 tag)进行过滤操作。这就意味着,Git 服务器不需要将代码库中所有的 ref 一次性发送给客户端。
在这之前,大型的代码库中,可能会存在不计其数的 ref,即使某些 ref 是客户端不需要使用的,也不得不加载多个 ref 数据。而在使用 v2 协议之后,Git 服务器将根据客户端所需要的操作类型,对 ref 进行过滤之后,再将列表发送至客户端。
如果开发者所更新的分支只是比其远程分支落后几个提交,或者是仅仅需要检查本地分支是否已经更新,那么完全没有必要在服务端传递整个 ref 列表,这对于时间和带宽来说都是一种浪费。
威廉姆斯表示,基于谷歌内部对协议 v2 的使用,在访问 Chrome 这种大型仓库时,比起使用 v1 协议,可以提高三倍的速度。此外,通过使用新版本协议,更便于实现某些新的特性,例如按需选取 ref,以及拉取和推送 symref 等。
对于支持协议 v2 的 Git 客户端,仍然可以与没有支持 v2 的旧版本服务端进行通信。因为最新的客户端是通过一个独立的通道,来发送 v2 所必须的额外信息。而旧版本的服务端会直接忽略这个额外的通道,并返回 ref 的完整列表。
另外,Git 2.18 中的另一个新特性是通过序列化的 commit graph 改善性能。简单来说,就是新版本的 Git 可以将 commit graph 的结构保存在某个文件中,并附加一些额外的元数据,以加速图形的加载。
这项功能是由微软的团队所实现的,据介绍,对于大型代码库,例如 Linux kernel 或 Git 本身的代码库进行这类操作时,速度可以提升 75%–99%。
但是,Git 的 commit graph 仍然是一项处于实验性阶段的功能,因为某些 Git 特性无法很好地与 commit graph 相配合,例如浅克隆、对象替换,以及 commit graft 等。
公开
同步至部落
取消
完成
0/2000
荧光笔
直线
曲线
笔记
复制
AI
- 深入了解
- 翻译
- 解释
- 总结
该免费文章来自《极客视点》,如需阅读全部文章,
请先领取课程
请先领取课程
免费领取
© 版权归极客邦科技所有,未经许可不得传播售卖。 页面已增加防盗追踪,如有侵权极客邦将依法追究其法律责任。
登录 后留言
全部留言(1)
- 最新
- 精选
- StackOverflow看了下官方文档,配置了下……却不生效…不晓得gerrit是否需要更新
收起评论