简记git与SVN

svn与git是目前比较主流的版本控制系统,在这里简单记录一下它们之间的异同。

一,从架构来说,SVN是集中式,git是分布式。

集中式的优点是代码高度统一,缺点也很明显就是非常依赖于中央服务器。如果服务器宕机或者本地

无法联网,那么你将无法提交更新、还原、对比等,也就无法协同工作。同时SVN上的提交也并非是

每次都成功,如果有一个人在你提交的时候先提交,那么就会提示你先更新再提交。SVN原理上只关

心文件内容的具体差异,每次记录有哪些文件做了更新并且更新了哪些内容。

而分布式的git会在本地克隆一个自己的版本库,在无法联网的时候,依然能够提交文件,查看历史版

本记录等。Git中每个版本库都是平等的。与SVN不同,Git只关心文件数据的整体是否发生变化,Git

并不保存文件内容前后变化的差异数据,更像是把变化的文件作快照后记录在一个微型的文件系统中

(为提高性能,没有变化的文件不会再次保存)。

二,版本库与工作区的差异

SVN的版本库与工作区是分离的。工作区在你本地检出的那个目录,它是一份版本库在某个历史状态

下的快照。SVN的工作区中每个目录下都包含一个名为.svn的控制目录(隐藏目录)。

git的版本库与工作区在同一个目录下,工作区的根目录有一个.git的子目录。git的工作区必须要有.git

目录,它是用来保存元数据和对象数据库的地方,并且Git的工作区下只有一个.git目录,此外再无任何

控制目录,如果删除它,则破环了整个历史,版本库也永远失去了。(可以在工作区之外克隆一个版

本库,并且经常把提交push到里面,这样就实现了数据备份。)

三,SVN采用全局版本号,且是连续的。Git是通过对文件的内容或目录的结构计算出一个哈希值,是

40为的十六进制字符串,它是全球唯一的。

四,SVN可以部分检出,而git只能全部检出。

五,SVN的更新可以使工作区和版本库保持一致,git上通过git fetch(fetch将远程数据库的object拷贝

到本地)和git pull(pull相当于fetch+merge)来完成远程更新任务。

六,提交与分支

SVN里的分支就是一个子目录,和普通的路径没有什么本质的区别。而git的分支仅是一个文件,所以

你可以在同一个工作目录下快速的在几个分支间切换。git的分支是完全隔离的。

SVN的提交是单线索的,它的提交链只有一条。Git的提交是多线索,提交链可以有多条。

在svn中,你无法去撤销提交,只能在后续的提交中修正。SVN有一个特性是它的信息从不丢失,即使

删除了,也可以在早期版本中找到。

Git的代码库属于个人,允许任意修改。Git通过git reset -hard可以永远丢弃最新的一个或几个提交。

总结:

SVN逻辑明确,符合一般人思维习惯;易于管理,集中式服务器更能保证安全性;代码一致性非常

高;适合开发人数不多的项目。缺点是,服务器压力太大,数据库容量暴增;如果不能连接到服务器

上基本不可以工作。

Git适合分布式开发,强调个体;公共服务器压力和数据量都不会太大;离线工作;任意两个开发者之

间很容易解决问题。缺点是,学习周期较长,代码保密性差。

简记git与SVN

时间: 2024-10-10 00:19:37

简记git与SVN的相关文章

【转】GIT和SVN之间的五个基本区别

如果你在读这篇文章,说明你跟大多数开发者一样对GIT感兴趣,如果你还没有机会来试一试GIT,我想现在你就要了解它了. GIT不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等.如果你是一个具有使用SVN背景的人,你需要做一定的思想转换,来适应GIT提供的一些概念和特征.所以,这篇文章的主要目的就是通过介绍GIT能做什么.它和SVN在深层次上究竟有什么不同来帮助你认识它. 那好,这就开始吧- 1.GIT是分布式的,SVN不是: 这是GIT和其它非分布式的版本控制系统,例如SVN

Git和SVN的区别,哪个好?

1) 最核心的区别Git是分布式的,而Svn不是分布的.能理解这点,上手会很容易,声明一点Git并不是目前唯一的分布式版本控制系统,还有比如Mercurial等,所以说它们差不许多.话说回来Git跟Svn一样有自己的集中式版本库和Server端,但Git更倾向于分布式开发,因为每一个开发人员的电脑上都有一个Local Repository,所以即使没有网络也一样可以Commit,查看历史版本记录,创建项 目分支等操作,等网络再次连接上Push到Server端. 从上面看GIt真的很棒,但是GIt

Android-版本控制Git和SVN

Android-版本控制Git和SVN 一 版本控制 版本控制是一种软件工程的技巧,确保在开发的过程中,由不同的人所编辑的相同的项目得到更新 二 版本控制的历史 版本控制的方式 本地版本控制 集中版本控制(SVN) 分布式版本控制(Git) 版本控制的使用历史 1 VCS 2 VSS CVS(不支持并发和原子提交) 3 CLearCase ,SVN, perforce, TFS 4 Mercurial(水星) , Git 三 版本控制-SVN 1 SVN架构 单机结构, 本地文件系统, 网络结构

GIT和SVN之间的五个基本区别

GIT不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等.如果你是一个具有使用SVN背景的人,你需要做一定的思想转换,来适应GIT提供的一些概念和特征.所以,这篇文章的主要目的就是通过介绍GIT能做什么.它和SVN在深层次上究竟有什么不同来帮助你认识它. 那好,这就开始吧… 1.GIT是分布式的,SVN不是: 这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别.如果你能理解这个概念,那么你就已经上手一半了.需要做一点声明,GIT并不是目前第一个或唯一的

Git 和 SVN 之间的五个基本区别

GIT不仅仅是个版本控制系统,它也是个内容管理系统(CMS),工作管理系统等.如果你是一个具有使用SVN背景的人,你需要做一定的思想转换,来适应GIT提供的一些概念和特征.所以,这篇文章的主要目的就是通过介绍GIT能做什么.它和SVN在深层次上究竟有什么不同来帮助你认识它. 那好,这就开始吧… 1.GIT是分布式的,SVN不是: 这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别.如果你能理解这个概念,那么你就已经上手一半了.需要做一点声明,GIT并不是目前第一个或唯一的

Git和SVN差异

转自:http://blog.csdn.net/huacuilaifa/article/details/19124635 在参加百度的开源项目时接触到Git,后来又陆续在微博上看到很多宣扬Git为程序员的比学工具,于是开始广泛收集了一些Git的电子书籍.网站等着自己“有时间”去消磨,一直拖到现在.由于自己实验室的项目的版本控制一直用的是SVN,先将二者区别总结如下: 1.版本控制的进化        本地版本控制系统                                        

蒋鑫:为什么 Git 比 SVN 好

在版本控制系统的选型上,是选择Git还是SVN? 对于开源项目来说这不算问题.使用Git极大地提高了开发效率.扩大了开源项目的参与度. 增强了版本控制系统的安全性,选择Git早已是大势所趋. 但对于企业用户来说这个决心不太好下.部分原因是出于对Git的误解,部分原因是尚不了解 Git到底能给项目管理带来什么好处.希望本文能对您项目的版本控制系统选型提供帮助. 对SVN的迷信和对Git的误解 误解1:SVN只能检出(checkout)一个版本(revision)的代码,而Git却可以脱库! 这个误

IOS xcode 删除git使用svn

一.为什么要这样做 由于git 与 svn这两个版本控制工具不能同时使用,在新建工程的时候Xcode5 默认选择了git,当然可以自己不选择.当无意默认了git版本控制,但有想使用svn版本控制,此时只有两种方法:1.重新建工程,2.删除git,使用svn; 二.解决方法 1.先关闭xcode,然后到终端界面,进入到相应的目录,手动删除.git文件或者用rm -fr .git 命令删除git. 2.关于.a等外部资源的提交 由于默认是将.a文件忽略和不提交的,因此需要修改下. vi ~/.sub

聊聊git和svn

Git is a free and open source distributed version control system designed to handle everything from small to very large projects with speed and efficiency. 上面这段话是git的官方解释:git是一个免费开源的分布式版本控制系统,它被设计用来高效快速处理从小到大的工程. 先来聊聊版本控制. https://git-scm.com/book/zh