Git 取得項(xiàng)目的倉(cāng)庫(kù)

2018-09-27 15:36 更新

有兩種取得 Git 項(xiàng)目倉(cāng)庫(kù)的方法。第一種是在現(xiàn)存的目錄下,通過導(dǎo)入所有文件來(lái)創(chuàng)建新的 Git 倉(cāng)庫(kù)。第二種是從已有的 Git 倉(cāng)庫(kù)克隆出一個(gè)新的鏡像倉(cāng)庫(kù)來(lái)。

在工作目錄中初始化新倉(cāng)庫(kù)

要對(duì)現(xiàn)有的某個(gè)項(xiàng)目開始用 Git 管理,只需到此項(xiàng)目所在的目錄,執(zhí)行:

$ git init

初始化后,在當(dāng)前目錄下會(huì)出現(xiàn)一個(gè)名為 .git 的目錄,所有 Git 需要的數(shù)據(jù)和資源都存放在這個(gè)目錄中。不過目前,僅僅是按照既有的結(jié)構(gòu)框架初始化好了里邊所有的文件和目錄,但我們還沒有開始跟蹤管理項(xiàng)目中的任何一個(gè)文件。(在第九章我們會(huì)詳細(xì)說(shuō)明剛才創(chuàng)建的 .git 目錄中究竟有哪些文件,以及都起些什么作用。)

如果當(dāng)前目錄下有幾個(gè)文件想要納入版本控制,需要先用 git add 命令告訴 Git 開始對(duì)這些文件進(jìn)行跟蹤,然后提交:

$ git add *.c

$ git add README

$ git commit -m 'initial project version'

稍后我們?cè)僦鹨唤忉屆織l命令的意思。不過現(xiàn)在,你已經(jīng)得到了一個(gè)實(shí)際維護(hù)著若干文件的 Git 倉(cāng)庫(kù)。

從現(xiàn)有倉(cāng)庫(kù)克隆

如果想對(duì)某個(gè)開源項(xiàng)目出一份力,可以先把該項(xiàng)目的 Git 倉(cāng)庫(kù)復(fù)制一份出來(lái),這就需要用到git clone 命令。如果你熟悉其他的 VCS 比如 Subversion,你可能已經(jīng)注意到這里使用的是 clone 而不是 checkout。這是個(gè)非常重要的差別,Git 收取的是項(xiàng)目歷史的所有數(shù)據(jù)(每一個(gè)文件的每一個(gè)版本),服務(wù)器上有的數(shù)據(jù)克隆之后本地也都有了。實(shí)際上,即便服務(wù)器的磁盤發(fā)生故障,用任何一個(gè)克隆出來(lái)的客戶端都可以重建服務(wù)器上的倉(cāng)庫(kù),回到當(dāng)初克隆時(shí)的狀態(tài)(雖然可能會(huì)丟失某些服務(wù)器端的掛鉤設(shè)置,但所有版本的數(shù)據(jù)仍舊還在,有關(guān)細(xì)節(jié)請(qǐng)參考第四章)。

克隆倉(cāng)庫(kù)的命令格式為 git clone [url]。比如,要克隆 Ruby 語(yǔ)言的 Git 代碼倉(cāng)庫(kù) Grit,可以用下面的命令:

$ git clone git://github.com/schacon/grit.git

這會(huì)在當(dāng)前目錄下創(chuàng)建一個(gè)名為grit的目錄,其中包含一個(gè) .git 的目錄,用于保存下載下來(lái)的所有版本記錄,然后從中取出最新版本的文件拷貝。如果進(jìn)入這個(gè)新建的 grit 目錄,你會(huì)看到項(xiàng)目中的所有文件已經(jīng)在里邊了,準(zhǔn)備好后續(xù)的開發(fā)和使用。如果希望在克隆的時(shí)候,自己定義要新建的項(xiàng)目目錄名稱,可以在上面的命令末尾指定新的名字:

$ git clone git://github.com/schacon/grit.git mygrit

唯一的差別就是,現(xiàn)在新建的目錄成了mygrit,其他的都和上邊的一樣。

Git 支持許多數(shù)據(jù)傳輸協(xié)議。之前的例子使用的是git:// 協(xié)議,不過你也可以用 http(s):// 或者 user@server:/path.git 表示的 SSH 傳輸協(xié)議。我們會(huì)在第四章詳細(xì)介紹所有這些協(xié)議在服務(wù)器端該如何配置使用,以及各種方式之間的利弊。

以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)