zoukankan      html  css  js  c++  java
  • Git和Svn的区别

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

    1.写代码

    2.提交到本地版本库

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

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

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

    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.需要连网,如果无法连接到服务器就无法提交代码

  • 相关阅读:
    MySQL学习(一) 概述
    Spring Tool Suite生成默认的MVC项目的配置文件问题
    [国家集训队]排队
    「PKUSC2018」最大前缀和
    「PKUSC2018」真实排名
    Min-Max容斥 & FMT
    SPOJ-CLFLARR 题解
    FFT详解
    CF Round#446 改题
    [CF1131D]Gourmet Choice 题解
  • 原文地址:https://www.cnblogs.com/pawn-i/p/11898038.html
Copyright © 2011-2022 走看看