Git学习

来源:互联网 发布:我知主掌握明天歌谱 编辑:程序博客网 时间:2024/06/05 14:48

     之前一直使用的是SVN,目前有机会就学习了一下git项目管理工具。

     Git是一个开源的分布式控制系统,用于敏捷高效的处理任何或大或小的项目。Git是Linus Torvalds为了帮助管理linux内核开发而开发的一个开放源码的版本控制软件。Git与常用的版本控制工具CVS,Subversion等不同,他采用了分布式版本库的方式,不必服务器端软件支持。

Git与SVN区别???

   GIT不仅仅是一个版本控制系统,它也是个内容管理系统(CMS)、工作管理系统等。

    如果你是一个具有使用SVN背景的人,比如我,你需要做一定的思想转换,来适应GIT提供的一些概念和特征。

Git与SVN区别点:

(1)GIT是分布式的,SVN不是:这是GIT和其他非分布式的版本控制系统(SVN、CVS)最核心的区别。

(2)GIT把内容按元数据方式存储,而SVN是按文件:所有的资源控制系统都是把文件的元信息隐藏在一个类似的svn,cvs等的文件夹里。

(3)GIT分支和SVN的分支不同:分支在SVN中一点不特别,就是版本库中 的另外的一个目录。

(4)GIT没有一个全局的版本号,而SVN有:目前为止这跟SVN相比GIT缺少的最大的一个特征。

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

Git安装配置

在使用Git前我们需要先安装Git。Git目前支持Linux/Unix、Solaris、Mac和Windows平台上运行。

Git各平台安装包下载地址为:http://git-scm.com/downloads。

在windows平台上安装Git很轻松,有个叫做msysGit的项目提供了安装包,可以做到GitHub的页面上下载exe安装文件并运行。

当安装完成之后,就可以使用命令行的git工具(已经自带了ssh客户端)了,另外还有一个图形界面的Git项目管理工具。

在开始菜单里找到Git->Git Bash 会弹出Git命令窗口,就可以在该窗口进行Git操作。

Git配置

Git提供了一个叫做git config的工具,专门用来配置或读取相应的工作环境变量。这些环境变量,决定了Git在各个环节的剧痛工作方式和行为。这些变量可以存放在以下三个不同的地方:

(1)/ect/gitconfig文件:系统中对所有用户都普遍适用的配置。若使用git config时用--system选项,读写的就是这个文件。

(2)~/.gitconfig文件:用户目录下的配置文件只使用于该用户。若使用git config时用--global选项,读写的就是这个文件。

(3)当前项目的Git目录中的配置文件(也就是工作目录中的.git/config文件):这里的配置仅仅针对当前项目有效。每一个级别的配置都会覆盖上层的相同配置,所以.git/config里的配置会覆盖/ect/gitconfig中的同名变量。

在windows系统上,Git会找寻用户主目录下的.gitconfig文件。主目录即$HOME变量指定的目录,一般都是C:\Documents and Setting\$USER。

此外,Git还会尝试找寻/ect/gitconfig文件,只不过看当初Git装在什么目录,就以此作为根目录来定位。

用户信息

配置个人的用户名称和电子邮件地址:

$ git config --global user.name "runoob"

$git config --global user.email test@runoob.com

如果用了--global选项,那么更改的配置文件就是位于你用户主目录下的那个,以后你所有的项目都会默认使用这里配置的用户信息。

如果要在某个特定的项目中使用其他名字或者电邮,只用去掉--global选项重新配置即可,新的设定保存字啊当前项目的.git/config文件里。

Git工作流程

一般的工作流程如下:

(1)克隆Git资源作为工作目录。

(2)在克隆资源上添加文件或修改文件。

(3)如果其他人修改了,可以更新资源。

(4)在提交前查看修改。

(5)提交修改。

(6)在修改完成后,如果发现错误,可以撤回提交并再次修改并提交。


Git工作区、暂存区和版本库的基本概念

(1)工作区:就是你在的电脑里能看到的目录。

(2)暂存区:英文叫stage或index。一般存放在‘。git目录下’下的index文件(.git/index)中,所以我们把暂存区有时也叫做索引。

(3)版本库:工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。

下面这个图展示了工作区、版本库中的暂存区和版本库之间的关系:


图中左侧为工作区,右侧为版本库,在版本库中标记为index的区域是暂存区(stage、index),标记为“master”的是master分支所代表的目录树。


未完待续。。。。。