git 是用於 linux 核心開發的版本控制工具。與常用的版本控制工具 cvs, subversion 等不同,它採用了分布式版本庫的方式,不必伺服器端軟體支援,使源**的發布和交流極其方便。 git 的速度很快,這對於諸如 linux kernel 這樣的大專案來說自然很重要。 git 最為出色的是它的合併跟蹤(merge tracing)能力。
安裝:第一步:sudo apt-get install git git-core 來安裝git程式,或者到新立得軟體包裡面 輸入 git然後安裝。
第二步:如果你已經安裝好git那麼通過下面命令來更新版本庫。
git clone git:
第三步:建立乙個版本庫git-init-db
建立乙個 git 版本庫是很容易的,只要用命令 git-init-db 就可以了
$ mkdir gittutorcn
$ cd gittutorcn
$ git-init-db
這樣,乙個空的版本庫就建立好了,並在當前目錄中建立乙個叫 .git 的子目錄。你可以用 ls -a 檢視一下,並請注意其中的三項內容:
乙個叫 head 的檔案,我們現在來檢視一下它的內容:
$ cat .git/head
現在 head 的內容應該是這樣:
ref: refs/heads/master
我們可以看到,head 檔案中的內容其實只是包含了乙個索引資訊,並且,這個索引將總是指向你的專案中的當前開發分支。
乙個叫 objects 的子目錄,它包含了你的專案中的所有物件,我們不必直接地了解到這些物件內容,我們應該關心是存放在這些物件中的專案的資料。
乙個叫 refs 的子目錄,它用來儲存指向物件的索引。
具體地說,子目錄 refs 包含著兩個子目錄叫 heads 和 tags,就像他們的名字所表達的意味一樣:他們存放了不同的開發分支的頭的索引, 或者是你用來標定版本的標籤的索引。
請注意:master 是預設的分支,這也是為什麼 .git/head 建立的時候就指向 master 的原因,儘管目前它其實並不存在。 git 將假設你會在 master 上開始並展開你以後的工作,除非你自己建立你自己的分支。
另外,這只是乙個約定俗成的習慣而已,實際上你可以將你的工作分支叫任何名字,而不必在版本庫中一定要有乙個叫 master 的分支,儘管很多 git 工具都認為 master 分支是存在的。
現在已經建立好了乙個 git 版本庫,但是它是空的,還不能做任何事情,下一步就是怎麼向版本庫植入資料了。
第四步:植入內容跟蹤資訊:git-add:
為了簡明起見,我們建立兩個檔案作為練習:
$ echo "hello world" > hello
$ echo "silly example" > example
我們再用 git-add 命令將這兩個檔案加入到版本庫檔案索引當中:
$ git-add hello example
git-add 實際上是個指令碼命令,它是對 git 核心命令 git-update-index 的呼叫。因此上面的命令和下面的命令其實是等價的:
$ git-update-index --add hello example
如果你要將某個檔案從 git 的目錄跟蹤系統中清除出去,同樣可以用 git-update-index 命令。例如:
$ git-update-index --force-remove foo.c
git-add 可以將某個目錄下的所有內容全都納入內容跟蹤之下,例如: git-add ./path/to/your/wanted 。但是在這樣做之前,應該注意先將一些我們不希望跟蹤的檔案清理掉,例如,gcc 編譯出來的 *.o 檔案,vim 的交換檔案 .*.swp 之類。
應該建立乙個清晰的概念就是,git-add 和 git-update-index 只是重新整理了 git 的跟蹤資訊,hello 和 example 這兩個檔案中的內容並沒有提交到 git 的內容跟蹤範疇之內。
第五步:提交內容到版本庫:git-commit
既然我們重新整理了 git 的跟蹤資訊,現在我們看看版本庫的狀態:
$ git-status
## initial commit##
# updated but not checked in:
# (will commit)
## new file: example
# new file: hello
#提示資訊告訴我們版本庫中加入了兩個新的檔案,並且 git 提示我們提交這些檔案,我們可以通過 git-commit 命令來提交:
$ git-commit -m "initial commit of gittutor reposistory"
第六步:檢視當前的工作:git-diff
git-diff 命令將比較當前的工作目錄和版本庫資料庫中的差異。現在我們編輯一些檔案來體驗一下 git 的跟蹤功能。
$ echo "it's a new day for git" >> hello
我們再來比較一下,當前的工作目錄和版本庫中的資料的差別。
$ git-diff
差異將以典型的 patch 方式表示出來:
diff --git a/hello b/hello
index 802992c..8fdaa4e 100644
--- a/hello
+++ b/hello
@@ -1 +1,2 @@
hello world
+it's a new day for git
此時,我們可以再次使用組合命令 git-update-index 和 git-commit 將我們的工作提交到版本庫中。
$ git-update-index hello
$ git-commit -m "new day for git"
實際上,如果要提交的檔案都是已經納入 git 版本庫的檔案,那麼不必為這些檔案都應用 git-update-index 命令之後再進行提交,下面的命令更簡捷並且和上面的命令是等價的。
$ git-commit -a -m "new day for git"
一些命令:
初始化git資料庫
$ git-init-db
新增檔案
$ git-add hello.c
檢視修改、提交記錄
$ git-log
建立分支
$ git-branch roredu
檢視分支
$ git-branch
* master
roredu
切換工作分支
$ git-checkout roredu
switched to branch "roredu"
$ git-branch
master
* roredu
提交到當前工作分支並書寫標記。
$ git-commit -a
建立xux分支對於master的補丁檔案。
$ git-format-patch master roredu
配置開發者自己的簽名和email。
$ git-config --global user.name "roredu"
$ git-config --global user.email "[email protected]"
修改檔名
$ git-mv roredu.c helight.c
刪除檔案
$ git-rm roredu.c
git-clone ssh@wtb:192.168.0.21/home/wtb/netbeansprojects/project1
這裡wtb是使用者名稱, 192.168.0.21是專案所在機器的ip 後面跟著的是專案目錄和名稱
Ubuntu下的Git的安裝與使用
1 安裝 ubuntu sudo apt get install git git core 2 配置使用者資訊 git config global user.name yourname git config global user.email yourname mail.com mkdir m070...
ubuntu下git安裝及使用
其實,好幾個月前,就已經安裝好了,可是一直擱置在那兒,所以密碼等一些其它細節都忘的差不多了,所以今天就重新部署了一下,並開始積極使用。1,git 安裝 sudo apt get install git core openssh server openssh client sudo apt get i...
ubuntu下git安裝及使用
其實,好幾個月前,就已經安裝好了,可是一直擱置在那兒,所以密碼等一些其它細節都忘的差不多了,所以今天就重新部署了一下,並開始積極使用。1,git 安裝 sudo apt get install git core openssh server openssh client sudo apt get i...