Git和SVN的主要区别

主要基本区别:

1.GIT是分布式的,SVN不是:

这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。如果你能理解这个概念,那么你就已经上手一半了。需要做一点声明,GIT并不是目前第一个或唯一的分布式版本控制系统。还有一些系统,例如BitkeeperMercurial等,也是运行在分布式模式上的。但GIT在这方面做的更好,而且有更多强大的功能特征。

GIT跟SVN一样有自己的集中式版本库或服务器。但,GIT更倾向于被使用于分布式模式,也就是每个开发人员从中心版本库/服务器上chect out代码后会在自己的机器上克隆一个自己的版本库。可以这样说,如果你被困在一个不能连接网络的地方时,就像在飞机上,地下室,电梯里等,你仍然能够提 交文件,查看历史版本记录,创建项目分支,等。对一些人来说,这好像没多大用处,但当你突然遇到没有网络的环境时,这个将解决你的大麻烦。

同样,这种分布式的操作模式对于开源软件社区的开发来说也是个巨大的恩赐,你不必再像以前那样做出补丁包,通过email方式发送出去,你只需要创建一个分支,向项目团队发送一个推请求。这能让你的代码保持最新,而且不会在传输过程中丢失。GitHub.com就是一个这样的优秀案例。

有些谣言传出来说subversion将来的版本也会基于分布式模式。但至少目前还看不出来。

2.GIT把内容按元数据方式存储,而SVN是按文件:

所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。如果你把.git目录的 体积大小跟.svn比较,你会发现它们差距很大。因为,.git目录是处于你的机器上的一个克隆版的版本库,它拥有中心版本库上所有的东西,例如标签,分 支,版本记录等。

3.GIT分支和SVN的分支不同:

分支在SVN中一点不特别,就是版本库中的另外的一个目录。如果你想知道是否合并了一个分支,你需要手工运行像这样的命令svn propget svn:mergeinfo,来确认代码是否被合并。感谢Ben同学指出这个特征。所以,经常会发生有些分支被遗漏的情况。

然而,处理GIT的分支却是相当的简单和有趣。你可以从同一个工作目录下快速的在几个分支间切换。你很容易发现未被合并的分支,你能简单而快捷的合并这些文件。

4.GIT没有一个全局的版本号,而SVN有:

目前为止这是跟SVN相比GIT缺少的最大的一个特征。你也知道,SVN的版本号实际是任何一个相应时间的源代 码快照。我认为它是从CVS进化到SVN的最大的一个突破。因为GIT和SVN从概念上就不同,我不知道GIT里是什么特征与之对应。如果你有任何的线 索,请在评论里奉献出来与大家共享。

更新:有些读者指出,我们可以使用GIT的SHA-1来唯一的标识一个代码快照。这个并不能完全的代替SVN里容易阅读的数字版本号。但,用途应该是相同的。

5.GIT的内容完整性要优于SVN:

GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏。

6)Git下载下来后,在本地不必联网就可以看到所有的log,很方便学习,SVN却需要联网;

7)SVN在Commit前,我们都建议是先Update一下,跟本地的代码编译没问题,并确保开发的功能正常后再提交,这样其实挺麻烦的,有好几次同事没有先Updata,就Commit了,发生了一些错误,耽误了大家时间,Git可能这种情况会少些。

其他区别:

1)速度:

克 隆一份全新的目录,以同样拥有五个(才五个)分支来说,SVN是同时复製5个版本的文件,也就是说重复五次同样的动作。而Git只是获取文件的每个版本的 元素,然后只载入主要的分支(master)。在我的经验,克隆一个拥有将近一万个提交(commit),五个分支,每个分支有大约1500个文件的 SVN,耗了将近一个小时!而Git只用了区区的1分鐘!

2)版本库(repository):

据我所知,SVN只能有一个指定中央版本库。当这个中央版本库有问题时,所有工作成员都一起瘫痪直到版本库维修完毕或者新的版本库设立完成。

而 Git可以有无限个版本库。或者,更正确的说法,每一个Git都是一个版本库,区别是它们是否拥有活跃目录(Git Working Tree)。如果主要版本库(例如:置於GitHub的版本库)发生了什麼事,工作成员仍然可以在自己的本地版本库(local repository)提交,等待主要版本库恢复即可。工作成员也可以提交到其他的版本库!

3)分支(Branch)

在SVN,分支是一个完整的目录。且这个目录拥有完整的实际文件。如果工作成员想要开啟新的分支,那将会影响“全世界”!每个人都会拥有和你一样的分支。如果你的分支是用来进行破坏工作(安检测试),那将会像传染病一样。

而 Git,每个工作成员可以任意在自己的本地版本库开啟无限个分支。举例:当我想尝试破坏自己的程序(安检测试),并且想保留这些被修改的文件供日后使用, 我可以开一个分支,做我喜欢的事。完全不需担心妨碍其他工作成员。只要我不合并及提交到主要版本库,没有一个工作成员会被影响。等到我不需要这个分支时, 我只要把它从我的本地版本库删除即可。无痛无痒。

Git的分支名是可以使用不同名字的。例如:我的本地分支名為testing,而在主要版本库的名字其实是master。

最值得一提,我可以在Git的任意一个提交点(commit point)开啟分支!(其中一个方法是使用gitk –all 可观察整个提交记录,然后在任意点开啟分支。)

4)提交(Commit)

在SVN,当你提交你的完成品时,它将直接记录到中央版本库。当你发现你的完成品存在严重问题时,你已经无法阻止事情的发生了。如果网路中断,你根本没办法提交!

而Git的提交完全属於本地版本库的活动。而你只需“推”(git push)到主要版本库即可。Git的“推”其实是在执行“同步”(Sync)。

5)重新设立起点(Rebase)

我没在SVN尝试过,不知道有没有这样的功能。

在 Git,如果你想把别人的最新提交设立為现在这个分支的起点,只要执行git rebase branch_name 即可。这个和合并(merge)不同点是,merge会依据修改的时间视為最新,而Rebase会要求你去解决双方都有修改过的地方的矛盾 (conflict)。

A - B - E

\- C - D

A - B - E

\ - C - D

6)系统档案

SVN会在每一个目录置放一个.svn。如果想移除这些.svn是很累的。

而Git会在目录起点拥有一个.git目录,以及.gitignore。

 

工作模式的区别:

无论是 svn 还是 git 的工作流,都是在本地解决冲突再提交,而不是在提交时解决冲突的。所以:

svn 的模式是:
1。写代码。
3。从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突。
5。将本地代码提交到服务器。

分布式版本管理的模式是:
1。写代码。
2。提交到本地版本库。
3。从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突。
4。将远程库与本地代码合并结果提交到本地版本库。
5。将本地版本库推到服务器。

所以,分布式版本管理仅仅是增加了本地库这个概念,其余的概念与集中管理并无区别。——但是 svn 在与服务器同步之前无法提交代码,因而本地修改更容易出问题。

### GitSVN 的技术差异比较 Git SVN 是两种主流的版本控制系统,它们在架构、数据存储、分支管理、网络依赖等方面存在显著的技术差异。以下是对这些差异的详细分析: #### 1. 架构模式:集中式 vs 分布式 Subversion (SVN) 是一个集中式的版本控制系统,所有的代码历史记录都存储在一个中央服务器上,开发者通过客户端与服务器进行交互,几乎所有操作(如提交、更新等)都需要联网才能完成 [^4]。而 Git 是分布式的版本控制系统,每个开发者本地都有一个完整的代码仓库副本,包括所有历史记录分支信息,这使得大多数操作可以在本地完成,只有在推送或拉取代码时才需要网络连接 [^1]。 #### 2. 数据存储方式 SVN 使用增量存储(delta storage)的方式记录文件变更,即每次提交只保存文件的差异部分。这种机制在某些情况下可以节省存储空间,但在处理大型项目时可能会导致性能下降 [^4]。Git 则采用快照(snapshot-based)的方式存储数据,每次提交都会保存整个项目的状态快照。虽然这种方式会占用更多磁盘空间,但它确保了每次提交的完整性,并提升了操作效率 [^3]。 #### 3. 分支与标签管理 Git 的分支机制非常轻量级,分支本质上是一个指向某个提交的指针,创建切换分支的操作非常快速。标签在 Git 中也是指针,指向特定的提交对象。这种设计使得 Git 在处理大量分支标签时表现优异 [^4]。相比之下,SVN 的分支标签是通过目录拷贝实现的,本质上是文件的硬链接或复制,因此创建管理成本较高,属于重量级操作 [^3]。 #### 4. 冲突处理机制 在 Git 中,冲突通常在本地解决,开发者可以在本地完成合并冲突解决后再将结果提交到远程仓库。这种方式减少了对服务器的依赖,并提高了协作效率 [^4]。而在 SVN 中,冲突通常在更新时被发现,开发者需要在服务器端解决冲突后才能继续提交更改,这种机制在多人协作时容易造成阻塞 [^3]。 #### 5. 网络依赖与性能 由于 SVN 是集中式系统,几乎所有操作都依赖于服务器连接,网络延迟可能显著影响开发效率 [^4]。Git 的分布式特性使得大部分操作(如提交、查看历史、分支切换等)都可以在本地完成,仅在与远程仓库同步时需要网络连接,因此在低带宽或不稳定网络环境下表现更佳 [^1]。 #### 6. 安全性与权限管理 SVN 的集中式架构更易于实施统一的权限管理机制,支持对分支、目录甚至文件级别的访问控制,适合需要严格权限控制的企业环境 [^5]。Git 本身在权限控制方面较弱,通常依赖于外部工具(如 GitLab、GitHub、Gitee 等平台)来实现细粒度的权限管理 [^3]。 #### 7. 适用场景对比 SVN 更适合团队规模较小、结构简单、对权限管理要求较高的项目,例如企业内部的项目开发 [^5]。Git 更适合大型开源项目、分布式团队协作、频繁分支与合并的开发模式,尤其适合敏捷开发流程 [^1]。 #### 8. 常用命令对比 | 操作 | Git 命令 | SVN 命令 | |------------------|------------------------------|---------------------------| | 初始化仓库 | `git init` | `svn create` | | 克隆仓库 | `git clone` | `svn checkout (co)` | | 添加文件 | `git add` | `svn add` | | 提交更改 | `git commit` | `svn commit (ci)` | | 更新代码 | `git pull` | `svn update (up)` | | 查看状态 | `git status` | `svn status (st)` | | 创建分支 | `git branch <branch-name>` | `svn copy <branch-name>` | | 删除分支 | `git branch -d <branch-name>`| `svn rm <branch-name>` | | 合并分支 | `git merge <branch-name>` | `svn merge <branch-name>` | | 查看差异 | `git diff` | `svn diff` | | 还原文件 | `git checkout -- <path>` | `svn revert <path>` | | 移动文件 | `git mv <old> <new>` | `svn mv <old> <new>` | ### 示例代码:Git 基本工作流程 ```bash # 初始化本地仓库 git init # 添加文件到暂存区 git add . # 提交更改到本地仓库 git commit -m "Initial commit" # 查看当前分支状态 git status # 创建并切换到新分支 git checkout -b feature-branch # 合并指定分支到当前分支 git merge feature-branch # 推送本地提交到远程仓库 git push origin main # 拉取远程更新 git pull origin main ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值