天天看点

git学习笔记

前不久(9月4号)git发布了2.10.0的新版本,趁机重新看了下git,顺手做个笔记。

简介

  Git是一个开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目。它是Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

Git与常用的版本控制工具CVS,Subversion等不同,它采用了分布式版本库的方式,不必服务器端软件支持。

Git 与 SVN 区别

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

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

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的安装

安装依赖包

Fedora系列:

<code>$ </code><code>sudo</code> <code>yum </code><code>install</code> <code>git-all</code>

源码包安装:

<code>$ </code><code>sudo</code> <code>yum </code><code>install</code> <code>curl-devel expat-devel gettext-devel \</code>

<code>  </code><code>openssl-devel perl-devel zlib-devel</code>

<code>add the documentation </code><code>in</code> <code>various formats (doc, html, info)</code>

<code>$ </code><code>sudo</code> <code>yum </code><code>install</code> <code>asciidoc xmlto docbook2X</code>

<code>$ </code><code>sudo</code> <code>ln</code> <code>-s </code><code>/usr/bin/db2x_docbook2texi</code> <code>/usr/bin/docbook2x-texi</code>

Debian-based系列(比如Ubuntu系列):

<code>$ </code><code>sudo</code> <code>apt-get </code><code>install</code> <code>git-all</code>

<code>$ </code><code>sudo</code> <code>apt-get </code><code>install</code> <code>libcurl4-gnutls-dev libexpat1-dev gettext \ </code>

<code> </code><code>libz-dev libssl-dev</code>

<code> </code><code>add the documentation </code><code>in</code> <code>various formats (doc, html, info)</code>

<code>$ </code><code>sudo</code> <code>apt-get </code><code>install</code> <code>asciidoc xmlto docbook2x</code>

下载源码包之后:

<code>$ </code><code>tar</code> <code>-zxf git-2.0.0.</code><code>tar</code><code>.gz</code>

<code>$ </code><code>cd</code> <code>git-2.0.0$ </code><code>make</code> <code>configure</code>

<code>$ .</code><code>/configure</code> <code>--prefix=</code><code>/usr</code>

<code>$ </code><code>make</code> <code>all doc info</code>

<code>$ </code><code>sudo</code> <code>make</code> <code>install</code> <code>install</code><code>-doc </code><code>install</code><code>-html </code><code>install</code><code>-info</code>

成功安装之后运行"git --version"可以查看当前的版本。

git的配置(git config)

  Git提供了一个叫做"git config"的工具,专门用来配置或读取相应的工作环境变量。

这些环境变量,决定了 Git 在各个环节的具体工作方式和行为。这些变量可以存放在以下三个不同的地方:

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

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

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

默认行为是--local;

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

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

  当你安装完git后的第一件事就是设置你的user name和email,因为每次git commit的时候都会用到这个信息:

<code>$ git config --global user.name </code><code>"runoob"</code>

<code>$ git config --global user.email </code><code>test</code><code>@runoob.com</code>

文本编辑器

  在用Git时,基本上都是以一行的commit信息来搞定的,比如git commit -m 'Hello World'。

但是有时要写详细点,就不能用-m了,这时git默认会打开传说中的nano来编辑提交信息!实际上弄成vim也很简单,编辑.git/config,在core这块,加入editor = vim.

<code>$ git config --global core.editor vim</code>

<code>export</code> <code>GIT_EDITOR=vim</code>

还有一个比较常用的是,在解决合并冲突时使用哪种差异分析工具。比如要改用 vimdiff 的话:

<code>$ git config --global merge.tool vimdiff</code>

Git 可以理解 kdiff3,tkdiff,meld,xxdiff,emerge,vimdiff,gvimdiff,ecmerge,和 opendiff 等合并工具的输出信息。

扩展一下:

在Ubuntu系统改变默认文本编辑器:

<code>$ update-alternatives --config editor</code>

<code>There are 5 choices </code><code>for</code> <code>the alternative editor (providing </code><code>/usr/bin/editor</code><code>).</code>

<code>Selection    Path                Priority   Status</code>

<code>------------------------------------------------------------</code>

<code>0            </code><code>/bin/nano</code>            <code>40        auto mode</code>

<code>1            </code><code>/bin/ed</code>             <code>-100       manual mode</code>

<code>2            </code><code>/bin/nano</code>            <code>40        manual mode</code>

<code>3            </code><code>/usr/bin/emacs24</code>     <code>0         manual mode</code>

<code>* 4            </code><code>/usr/bin/vim</code><code>.basic   30        manual mode</code>

<code>5            </code><code>/usr/bin/vim</code><code>.tiny    10        manual mode</code>

<code>Press enter to keep the current choice[*], or </code><code>type</code> <code>selection number:</code>

<code>选择你常用的editor,之后改变环境变量:</code>

<code>$ </code><code>export</code> <code>VISUAL=vim </code>

<code>$ </code><code>export</code> <code>EDITOR=</code><code>"$VISUAL"</code>

查看配置信息

要检查已有的配置信息,可以使用 git config --list 命令:

<code>$ git config --list</code>

<code>http.postbuffer=2M</code>

<code>user.name=runoob </code>

<code>user.email=</code><code>test</code><code>@runoob.com</code>

克隆到指定目录:

<code>$ git clone https:</code><code>//github</code><code>.com</code><code>/libgit2/libgit2</code> <code>mylibgit</code>

克隆到指定的目录‘mylibgit’,如果什么都不跟,克隆到默认原目录。

      本文转自Jx战壕  51CTO博客,原文链接:http://blog.51cto.com/xujpxm/1858888,如需转载请自行联系原作者

继续阅读