ubuntu下git安裝與使用筆記

2021-06-07 13:09:12 字數 3787 閱讀 1395

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...