Git和Svn的区别

Git和Svn的区别
  Git(分布式版本控制系统) Svn(集中式版本控制系统)
定义  Git是目前世界上最先进的分布式版本控制系统。 SVN是Subversion的简称,是一个开放源代码的版本控制系统,说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的。
工作流程 Git和Svn的区别

1.写代码

2.提交到本地版本库

3.从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突

4.将远程库与本地代码合并结果提交到本地版本库

5.将本地版本库推到服务器

Git和Svn的区别

1.写代码

2.从服务器拉回服务器的当前版本库,并解决服务器版本库与本地代码的冲突

3.将本地代码提交到服务器

是否有*服务器

没有*服务器,开发人员本地都有 Local Repository

 有。开发人员需要从*服务器获得最新版本的项目然后在本地开发,开发完推送给*服务器。因此脱离服务器开发者是几乎无法工作的

网络依赖

 分布式在没有网络的情况下也可以执行commit、查看版本提交记录、以及分支操作,在有网络的情况下执行 push 到 Remote Repository。

 必须要联网才能工作,而且对网络的依赖性较强,如果推送的文件比较大而且网络状况欠佳,则提交文件的速度会受到很大的限制。

文件存储格式

按照元数据方式存储,体积很小

按照原始文件存储,体积较大

分支操作影响

分支操作不会影响其他开发人员

创建新的分支则所有的人都会拥有和你一样的分支

提交过程

提交是本地操作,需要执行push操作才会到主要版本库

提交的文件会直接记录到*版本库

优势

1.分布式管理:Git是没有中心服务器的,每个人机器上都是一个完整的库

2.离线工作:(1)断网提交至本地库(2)本地回滚

3.分支策略:在Git实际开发中分支的分离和合并是属于日常操作,开启和合并分支成本相比SVN要小得多:SVN是复制一份代码到分支目录,Git则是在分支点做一下标。

1.集中式管理,管理方式在服务端配置好,客户端只需要同步提交即可,使用方便,操作简单,很容易就可以上手

2.在服务端统一控制好访问权限,利用代码的安全管理。

3.所有的代码以服务端为准,代码一致性高。

缺点

1.模式上比SVN更加复杂

2.代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息  

1.所有操作都需要通过服务端进行同步,这会导致服务器性能要求比较高。如果服务器宕机了就无法提交代码了。

2.分支管理不灵活,svn分支是一个完整的目录,且这个目录拥有完整的实际文件,这些操作都是在服务端进行同步的,不是本地化操作,如果要删除分支,也是需要将远程的分支进行删除,这会导致大家都得同步

3.需要连网,如果无法连接到服务器就无法提交代码