QCon北京「鸿蒙专场」火热来袭!即刻报名,与创新同行~ 了解详情
写点什么

软件企业从 Subversion 迁移到 Git ,真的准备好了吗?

  • 2012-09-03
  • 本文字数:2025 字

    阅读完需:约 7 分钟

除了人,软件公司最宝贵的就是代码了,这些代码大多储存在 Subversion(以下简称”SVN”) 这样开源的版本控制系统(VCS)中。代码是容易修改和变更的,因此,代码的备份、历史追踪、协同编辑等任务同样需要版本控制系统完成。从最早本地 VCS 系统 RCS、1990 年 CVS、2000 年 SVN,到如今开源世界风头正健的 Git,同语言编辑工具一样,SVN、Git 都是程序员的必备利器。随着 GitHub 的流行,很多软件企业开始计划转向 Git,但是企业真的准备好了吗?

从 SVN 到 Git,不仅仅是工具的替换,还有基于其上的工具和一些管理流程的变化。笔者建议:软件企业需要评估自己当前的状态和企业文化,认真考虑商业目标,谨慎迁移。我们不妨从以下几点来探讨一下。

陡峭的学习曲线

对于采用 SVN 进行管理的企业,Git 相对复杂,开发工程师的学习曲线并不平缓。

Git 的命令分为高层和底层,常用的高层命令约有 30 多个,与 SVN 近似。这些操作不能继承 SVN 的经验,因此工程师需要重新学习 branch、merge、reset、rebase、revert、pull、fetch 等操作命令,需要重新了解哈希值格式的版本号,并用它来进行检出、比较等。

对于较多使用 word、ppt、excel、图片、IDE 等工具的人员来说,从类似 FTP 的 SVN 转向 Git ,学习过程会比较痛苦。

缺少角色授权和文件级访问控制

Git 作为开源自由原教旨主义项目,它没有对版本库的浏览和修改做任何的权限限制。Git 的创始人 Linus Torvalds 也曾说:“不要让权限成为政治的理由,Git 没有权限控制。”

由于缺少角色授权,因此在组织结构管理上比较困难。实际操作中,一个 Git 仓库用来实现一个项目,大型项目可能需要许多 Git 仓库配合实现。在 SVN 中不同项目在不同目录中,通过角色授权完成组织结构的规划。

实现商业目标的软件企业显然需要文档或代码的访问授权和控制,目前 Git 本身是不支持的,需要集成第三方工具实现访问控制。

有限的目录检出功能

SVN 是一个中心仓库和众多客户端目录的关系,因此,SVN 用户都熟悉工作在某个目录上,在不同的工作计算机上,检出目录就可以编辑。然而,Git 是一个中心仓库和众多客户端仓库的关系,你必须工作在整个仓库上,虽然在 Git1.7 版本后支持了类似目录检出的功能,但仍要先检出整个仓库。软件企业的工程师常同时在多个项目中工作,如果修改一点东西就需要克隆仓库,对故障响应将有影响。

浪费已投入的开发成本

软件开发生命周期管理工具的基础是版本控制系统,各商业软件开发管理平台都是基于自主研发的版本控制系统,在此基础上扩展到项目管理、文档管理、代码评审、发布部署、缺陷管理等。基于 SVN 的开源或自主研发的管理工具非常成熟多样。迁移到 Git,则完全浪费了投入到 SVN 管理工具的开发成本。

图形化工具及接口不够强

虽然 Git 的图形工具正在增多,但在 Windows 下还需要等待这些开源工具增强功能。同时,Git 的接口待加强,与众多工具集成待完善,这些都是需要时间来解决。

目前很多人倡导的 Git 的优点并非不可替代

Git 速度快,但是 SVN 使用用廉价的高性能主机同样可以提升速度;Git 无需网路也可以工作,但当前稳固的网络基础环境和多样的接入方式,让 SVN 并不担心网络问题。另外 Git 方便地处理分支的特性,如果通过控制开发节奏,增加评审,减少分支数量,就可以让分支合并更简单快键,开发会更有效率,SVN 也可以更好地管理分支。 SVN 的 1.7 版本以不兼容旧版客户端的代价新增和改进了很多功能,开始向 Git 靠拢,这也使 SVN 具备 Git 的特性。

鉴于以上分享的几个基本点,建议企业谨慎迁移。

笔者对某些场景的命令进行了比较,下表是在 Git-1.7 和 SVN-1.6 上测试的,目的是为了说明 SVN 的操作经验在 Git 上不能直接套用,当然 Git 也有许多独特的优秀功能。

场景 SVN Git 操作动作追踪 所有的操作均作为一次提交,并分配版本号,可追踪 可以撤销某次提交、合并的动作,好像没有发生一样 引用公共库 用链接目录实现
$svn propset svn:externals < module name> < repository_url> Git 先克隆仓库,再用子模块方式实现
$git clone < repository_url> < directory>
$git submodule add < repository_url> 在本地检出目录 用检出功能实现
$ svn co < repository_url> < directory> 需要先克隆仓库,激活目录检出功能, 通过配置需要保留的目录实现
$git clone < repository_url> < directory>
$cd < directory>
$git config core.sparsecheckout true
$echo < directory> >> .git/info/sparse-checkout
$git read-tree -m -u HEAD 新增文件到中心仓库 用提交功能实现
$svn add < file>
$svn commit –m “new file” 提交后,需要推送到中心仓库
$git add < file>
$git commit –m “new file”
$git push origin## 作者简介

李新,新浪产品部高级配置管理工程师,有丰富的软件流程方面的经验。


感谢黄玲艳对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2012-09-03 00:007939

评论

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

PHP中出现Cannot modify header information - headers already sent

ModStart

软件测试 | 跨平台API对接

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

测试

从ChatGPT的技术发展角度解析未来智能化的发展方向

加入高科技仿生人

人工智能 AI 低代码 智能化 ChatGPT

瓴羊Quick BI提供移动端自助分析解决方案, 易于性高于 Fine BI、 Smart BI

流量猫猫头

大数据 数据分析

还在头疼你的API,送你一个保姆级的API设计管理平台

华为云开发者联盟

云计算 开发 华为云 华为云开发者联盟 企业号 3 月 PK 榜

极狐GitLab DevSecOps 为企业许可证安全合规保驾护航

极狐GitLab

许可证 DevSecOps 极狐GitLab 安全左移 安全合规

如何在服务端渲染fabric.js

ModStart

Centos 环境搭建

流火

Linux centos Centos 7

文件传输协议的五种安全文件传输替代方案

镭速

如何通过C#和VB.NET压缩PDF文档

Geek_249eec

C# .net PDF VB.NET

国内“谁”能实现chatgpt,一文带你深入了解宏观技术路线| 社区征文

汀丶人工智能

ChatGPT

博睿数据入选中国信通院《高质量数字化转型产品及服务全景图》

博睿数据

可观测性 智能运维 博睿数据 信通院 高质量发展

软件测试/测试开发 | 测试平台开发-前端开发之数据展示与分析

测试人

软件测试 自动化测试 测试开发 测试平台

软件测试 | ECharts简介与安装

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

测试

政企专属的IM即时通讯平台,促进团队安全沟通与协作

BeeWorks

吹爆Alibaba自研的Spring全能笔记,建议人手一份!

小小怪下士

Java spring springmvc springboot

Java Agent场景性能测试分析优化经验分享

华为云开发者联盟

开发 华为云 java 华为云开发者联盟 企业号 3 月 PK 榜

Spring Boot是如何内嵌Tomcat的?原理剖析

做梦都在改BUG

Java tomcat Spring Boot

AI开发实践丨客流分析之未佩戴口罩识别

华为云开发者联盟

人工智能 华为云 华为云开发者联盟 企业号 3 月 PK 榜

该如何正确的中断一个线程的执行

华为云开发者联盟

开发 华为云 华为云开发者联盟 企业号 3 月 PK 榜

1.基于Label studio的训练数据标注指南:信息抽取(实体关系抽取)、文本分类等

汀丶人工智能

数据标注 关系抽取 labelstudio 实体抽取

坚如磐石:TiDB 基于时间点的恢复(PiTR)特性优化之路丨6.5 新特性解析

PingCAP

TiDB

主题别名(Topic Alias)-MQTT 5.0新特性

EMQ映云科技

物联网 IoT mqtt 企业号 3 月 PK 榜 主题别名

软件测试 | Vuetify框架

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

测试

4道数学题,求解极狐GitLab CI 流水线|第4题:合并列车

极狐GitLab

ci DevOps pipeline runner 合并列车

SVN vs Git 不是技术之争,而是生态之争

极狐GitLab

git svn DevOps 版本控制 极狐GitLab

国内“谁”能实现chatgpt,对MOSS、ChatYuan给出关键技术简评,一文带你深入了解宏观技术路线| 社区征文

汀丶人工智能

ChatGPT

软件开发,如何同时保证效率和质量?

飞算JavaAI开发助手

百度点石隐私计算平台与FATE开源框架实现互联互通

百度安全

人工智能 开源 联邦学习 开发

软件企业从Subversion迁移到Git ,真的准备好了吗?_架构_李新_InfoQ精选文章