2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

放弃 SVN,苹果 WebKit 迁移到 GitHub

  • 2022-09-02
    北京
  • 本文字数:1301 字

    阅读完需:约 4 分钟

放弃SVN,苹果WebKit迁移到GitHub

版本控制系统 (VCS),又叫修订控制或源控制系统,是一种软件实用程序,用于跟踪和管理对文件系统的更改。几乎所有软件的代码的备份、历史追踪、协同编辑等任务都需要版本控制系统完成。


从最早本地 VCS 系统 RCS、1990 年 CVS、2000 年 SVN(Subversion),到如今开源世界风头正健的 Git,同语言编辑工具一样,SVN、Git 都是程序员的必备利器。近些年,随着 GitHub 的流行,很多软件纷纷转向 Git。


8 月 31 日,苹果 WebKit 项目运营工程师 Jonathan Bedard 发布博文称,在今年 6 月 23 日,WebKit 项目冻结了 Subversion 树,迁移到托管在 GitHub 的 Git 源代码管理系统。


为什么选择 Git?


WebKit 原先使用 Apache 的源代码管理系统 SVN,这次之所以迁移,是因为 WebKit 社区意识到了 Git 分布式特性的重要性和其庞大的社区。


SVN 是集中式的系统,而 Git 的分布式特性使开发人员在项目协作方式方面更加灵活,允许多个组织协作。


“Git 的本地提交消息记录,以及 Git 日志将提交历史限制在存储库的某些部分的能力,意味着大型项目不再需要在每次提交时检查过时的 ChangeLog 文件,” Bedard 说。


而且,WebKit 项目的许多新贡献者更倾向于在 git-svn 镜像上工作,当涉及到现有的工具和工作流程时,这样的转换也被视为理所当然的。


Bedard 进一步表示,“选择托管在 GitHub 是因为它有庞大的 Web 开发者社区,WebKit 项目能与他们密切合作以改进引擎。我们还发现,GitHub 的 API 让我们只需对现有的基础设施进行相对较小的修改,就能建立起先进的预提交和后提交自动化,并提供一个现代且安全的平台来审查和提供有关新代码更改的反馈。”

迁移是好事吗


用户可能会发现苹果此举令人沮丧的是,Git 哈希值并不是自然排序的,所以 WebKit 团队决定在需要分叉的工作流程中使用他们所谓的“提交标识符(commit identifiers)”。WebKit 有一个“零容忍性能退步”政策,这意味着,能够轻松推理出存储库中的提交顺序是至关重要的。


许多开发者都在问为什么这样的迁移需要这么长时间,并不是所有的人都认为这是一个好主意。


“仅在今年,GitHub 就发生了 50 多次故障,而且在追索方面也有糟糕的历史,限制受美国贸易制裁国家的开发者。如果‘WebKit 项目对世界各地的开发者的贡献和反馈感兴趣’,那么切换到 GitHub 是没有意义的。”一位用户在 HackerNews 论坛上评论道。


还有人表示,即使最终项目发展会变成更顺利,但过渡到 Git 的过程也是场噩梦。


但也正如一位用户所说:“鉴于 GitHub 是一个被普遍理解的主机,而且它有人们喜欢的所有 UI/开发集成,所以使用它是有意义的。另外,拥有 GitHub 账户的人似乎越来越多,因此贡献者不必再创建另一个帐户来提供其他服务。”


Git 由 Linus 在 2005 年开发而来,演化至今已经成为了最流行和最先进的开源版本控制工具,不过仍然有很多的公司和团队还在使用 SVN 或者 CVS 对项目进行版本控制,部分公司确实有一些可能合理的原因来维持现状,但是使用 Git 在绝大多数的场景下确实能让我们的开发和合作变得更加高效。


参考链接:

https://webkit.org/blog/13140/webkit-on-github/

https://www.theregister.com/2022/09/01/webkit_migrates/

https://www.infoq.cn/article/ahoxlss6g153hod0y5iz

2022-09-02 15:5412580
用户头像
罗燕珊 AI practitioner | Tech media

发布了 581 篇内容, 共 447.6 次阅读, 收获喜欢 870 次。

关注

评论 2 条评论

发布
用户头像
Linus 才是这个世界上唯一会编写程序的人,其它人都是学习他。
2022-09-05 14:53 · 浙江
回复
用户头像
Linus 才是这个世界上唯一会编写程序的人,其它人都是学习他。
2022-09-05 07:23 · 广东
回复
没有更多了
发现更多内容

富滇银行完成数字化升级|OceanBase数据库助力布局分布式架构中台

OceanBase 数据库

oceanbase 富滇银行

如何获得一场黑客马拉松的胜利?听听AWS特约评委怎么说

FinClip

小程序 黑客马拉松 finclip

IOC思想开窍之路

留乘船

Java spring ioc

智能手表的机遇与挑战

Geek_99967b

物联网

Web 编程入门:什么是Web API?

宇宙之一粟

Web API 5月月更

所有资产都在涨,只有比特币在挨打

CECBC

有IDE工具能让小程序快速运行在自有App上?

Speedoooo

ide 开发者工具 开发工具 小程序ide

给微信小程序配一个App如何?

FinClip

finclip 小程序转app

在线文本左边批量添加字符串工具

入门小站

工具

王者荣耀商城异地多活架构设计

小虾米

架构师实战营

中国AI:在"相牛班"的春天里

白洞计划

Flutter 基于 WebSocket 实现即时通讯

岛上码农

flutter ios 安卓开发 跨平台开发 5月月更

模块七

ASCE

linux删除目录下文件的几种方法

入门小站

近一个月B站封禁直播间1874个:直播行业仍然是违规重灾区

石头IT视角

小程序生态构建能力,离不开UI定制自由

Speedoooo

ide 小程序ide

小程序转App仅需7步

Speedoooo

ide APP开发 小程序转app 前端IDE

leetcode 4. Median of Two Sorted Arrays 寻找两个正序数组的中位数(困难)

okokabcd

LeetCode 查找

模块3-外包学生管理系统架构文档

Fan

「架构实战营」

如何在 JavaScript 中让代码更加精简

devpoint

ES6 6月月更

3000帧动画图解MySQL为什么需要binlog、redo log和undo log

CoderW

后端 面试题 Binlog Redo Log MySQL 数据库

中小互联网公司研发效能团队规模、职能划分和优劣势分析

laofo

DevOps cicd 研发效能 持续交付 互联网公司

在FinClip Hackathon中夺冠是一种什么样的体验?

FinClip

小程序 黑客马拉松 finclip

融云斩获2022年中国信创产业拳头奖“最佳通信与视频会议品牌”大奖

融云 RongCloud

竟然能在App里拉起一个小程序?

Geek_99967b

小程序

小程序如何与智能电视相结合?

Geek_99967b

小程序

内存性能测试工具

穿过生命散发芬芳

5月月更 内存性能测试

激活数字经济澎湃动能

CECBC

flutter系列之:flutter架构什么的,看完这篇文章就全懂了

程序那些事

flutter 架构 程序那些事 5月月更

小程序经济,已经开始制约中小企业的服务及合作

Geek_99967b

小程序

在线HTML转ASP工具

入门小站

工具

放弃SVN,苹果WebKit迁移到GitHub_文化 & 方法_罗燕珊_InfoQ精选文章