Git学习

定义

Git是一款免费、开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目

同类技术

CVS

CVS(Concurrent Version System)是一个C/S系统、一个常用的代码版本控制软件。CVS版本控制系统是一种GNU软件包,主要在开源软件管理中使用,在多人开发环境下对源码进行维护

SVN

SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。互联网上很多版本控制服务已从CVS迁移到Subversion。说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的

功能特性

开发者角度

从服务器上克隆数据库(包括代码和版本信息)到单机上
在自己的机器上创建分支,修改代码
在单机上自己创建的分支上提交代码
在单击上自己创建的分支上提交代码
在单击上合并分支
新建一个分支,把服务器上最新版的代码fetch下来,然后跟自己的主分支合并。
生成补SVN是Subversion的简称,是一个开放源代码的版本控制系统,相较于RCS、CVS,它采用了分支管理系统,它的设计目标就是取代CVS。互联网上很多版本控制服务已从CVS迁移到Subversion。说得简单一点SVN就是用于多个人共同开发同一个项目,共用资源的目的丁(patch),把补丁发送给主开发者
看主开发者的反馈,如果主开发者发现两个一般开发者之间有冲突(他们之间可以合作解决的冲突),就会要求他们先解决冲突,然后再由其中一个人提交。如果主开发者可以自己解决,或者没有冲突,就通过
一般开发者之间解决冲突的方法,开发者之间可以使用pull 命令解决冲突,解决完冲突之后再向主开发者提交补丁

主开发者角度

查看邮件或者通过其它方式查看一般开发者的提交状态。
打上补丁,解决冲突(可以自己解决,也可以要求开发者之间解决以后再重新提交,如果是开源项目,还要决定哪些补丁有用,哪些不用)
向公共服务器提交结果,然后通知所有开发人员

特点

缺点

资料少(起码中文资料很少)
学习周期相对而言比较长
不符合常规思维
代码保密性差,一旦开发者把整个库克隆下来就可以完全公开所有代码和版本信息

优点

适合分布式开发,强调个体
公共服务器压力和数据量都不会太大
速度快、灵活
任意两个开发者之间可以很容易的解决冲突
离线工作

组成部分

HEAD文件指示目前被检出(checkout)的分支
index文件(尚待创建)保存暂存区信息
objects目录存储所有数据内容
refs目录存储指向数据(分支)的提交对象的指针

问题解决

集中式版本控制系统最大的毛病就是必须联网才能工作
和集中式版本控制系统相比,分布式版本控制系统的安全性要高很多,因为每个人电脑里都有完整的版本库,某一个人的电脑坏掉了不要紧,随便从其他人那里复制一个就可以了。而集中式版本控制系统的中央服务器要是出了问题,所有人都没法干活了。

你可能感兴趣的:(Git学习)