天天看點

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,如需轉載請自行聯系原作者

繼續閱讀