zoukankan      html  css  js  c++  java
  • Git,SVN,Github,码云之间的区别

    原文:http://baijiahao.baidu.com/s?id=1605566374654856802&wfr=spider&for=pc 
    Git和SVN的区别

    1.GIT是分布式的,而SVN不是。这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。 
    需要做一点声明,GIT并不是目前第一个或唯一的分布式版本控制系统。还有一些系统,例如Bitkeeper, Mercur 
    ial等,也是运行在分布式模式上的。但GIT在这方面做的更好,而且有更多强大的功能特征。

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

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

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

    3.GIT分支和SVN的分支不同。分支在SVN中一点不特别,就是版本库中的另外的一个目录。如果你想知道是否 
    合并了一个分支,你需要手工运行像这样的命令svn propget svn:mergeinfo,来确认代码是否被合并。 然而,处 
    理GIT的分支却是相当的简单和有趣。你可以从同一个工作目录下快速的在几个分支间切换。你很容易发现未被 
    合并的分支,你能简单而快捷的合并这些文件。

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

    Git和GitHub、GitLab

    GitHub、GitLab是基于web的Git repositories(仓库)。 
    GitLab模仿GitHub,GitLab拥有GitHub拥有的一切,还拥有更多的安全性和灵活性。 
    GitLab拥有GitHub拥有的一切,但他拥有更多——让团队对它们的repositories拥有更多的控制

    码云和GitHub

    码云的服务器在国内,在国内访问速度比github快很多,可以免费让自己的仓库他人不可见,但是否安全 
    就不知道了。访问速度很快,支持svn,git两种方式,免费账户同样可以建立私有项目,而github上要建 
    立私有项目必须付费。

  • 相关阅读:
    Hdfs详解
    HDFS主要特性和体系结构
    HDFS简单入门
    使用docker搭建hadoop分布式集群
    HDFS理论及安装部署
    Android开发之模拟器genymotion安装apk出现错误: Install_failed_invalid_URI
    Android开发之最火的开源框架之一Xutils2详解(摘自开源作者官方介绍详解)
    Java开发之javaEE(java2EE)的介绍,java软件工程师初步阶段知识
    拾色器,可以取出电脑屏幕的任何颜色,ui以及程序员前端等常用软件,文件很小,300K
    Android开发必有功能,更新版本提示,检测是否有新版本更新。下载完成后进行安装。
  • 原文地址:https://www.cnblogs.com/chengzi-he/p/9559220.html
Copyright © 2011-2022 走看看