W3Cschool
恭喜您成為首批注冊(cè)用戶
獲得88經(jīng)驗(yàn)值獎(jiǎng)勵(lì)
開(kāi)始架設(shè) Git 服務(wù)器前,需要先把現(xiàn)有倉(cāng)庫(kù)導(dǎo)出為裸倉(cāng)庫(kù) — 即一個(gè)不包含當(dāng)前工作目錄的倉(cāng)庫(kù)。做法直截了當(dāng),克隆時(shí)用 --bare
選項(xiàng)即可。裸倉(cāng)庫(kù)的目錄名一般以 .git
結(jié)尾,像這樣:
$ git clone --bare my_project my_project.git
Cloning into bare repository 'my_project.git'...
done.
該命令的輸出或許會(huì)讓人有些不解。其實(shí) clone
操作基本上相當(dāng)于 git init
加 git fetch
,所以這里出現(xiàn)的其實(shí)是 git init
的輸出,先由它建立一個(gè)空目錄,而之后傳輸數(shù)據(jù)對(duì)象的操作并無(wú)任何輸出,只是悄悄在幕后執(zhí)行?,F(xiàn)在 my_project.git
目錄中已經(jīng)有了一份 Git 目錄數(shù)據(jù)的副本。
整體上的效果大致相當(dāng)于:
$ cp -Rf my_project/.git my_project.git
但在配置文件中有若干小改動(dòng),不過(guò)對(duì)用戶來(lái)講,使用方式都一樣,不會(huì)有什么影響。它僅取出 Git 倉(cāng)庫(kù)的必要原始數(shù)據(jù),存放在該目錄中,而不會(huì)另外創(chuàng)建工作目錄。
有了裸倉(cāng)庫(kù)的副本后,剩下的就是把它放到服務(wù)器上并設(shè)定相關(guān)協(xié)議。假設(shè)一個(gè)域名為 git.example.com
的服務(wù)器已經(jīng)架設(shè)好,并可以通過(guò) SSH 訪問(wèn),我們打算把所有 Git 倉(cāng)庫(kù)儲(chǔ)存在 /opt/git
目錄下。只要把裸倉(cāng)庫(kù)復(fù)制過(guò)去:
$ scp -r my_project.git user@git.example.com:/opt/git
現(xiàn)在,所有對(duì)該服務(wù)器有 SSH 訪問(wèn)權(quán)限,并可讀取 /opt/git
目錄的用戶都可以用下面的命令克隆該項(xiàng)目:
$ git clone user@git.example.com:/opt/git/my_project.git
如果某個(gè) SSH 用戶對(duì) /opt/git/my_project.git
目錄有寫權(quán)限,那他就有推送權(quán)限。如果到該項(xiàng)目目錄中運(yùn)行 git init
命令,并加上 --shared
選項(xiàng),那么 Git 會(huì)自動(dòng)修改該倉(cāng)庫(kù)目錄的組權(quán)限為可寫(譯注:實(shí)際上 --shared
可以指定其他行為,只是默認(rèn)為將組權(quán)限改為可寫并執(zhí)行 g+sx
,所以最后會(huì)得到 rws
。)。
$ ssh user@git.example.com
$ cd /opt/git/my_project.git
$ git init --bare --shared
由此可見(jiàn),根據(jù)現(xiàn)有的 Git 倉(cāng)庫(kù)創(chuàng)建一個(gè)裸倉(cāng)庫(kù),然后把它放上你和同事都有 SSH 訪問(wèn)權(quán)的服務(wù)器是多么容易?,F(xiàn)在已經(jīng)可以開(kāi)始在同一項(xiàng)目上密切合作了。
值得注意的是,這的的確確是架設(shè)一個(gè)少數(shù)人具有連接權(quán)的 Git 服務(wù)的全部 — 只要在服務(wù)器上加入可以用 SSH 登錄的帳號(hào),然后把裸倉(cāng)庫(kù)放在大家都有讀寫權(quán)限的地方。一切都準(zhǔn)備停當(dāng),無(wú)需更多。
下面的幾節(jié)中,你會(huì)了解如何擴(kuò)展到更復(fù)雜的設(shè)定。這些內(nèi)容包含如何避免為每一個(gè)用戶建立一個(gè)賬戶,給倉(cāng)庫(kù)添加公共讀取權(quán)限,架設(shè)網(wǎng)頁(yè)界面,使用 Gitosis 工具等等。然而,只是和幾個(gè)人在一個(gè)不公開(kāi)的項(xiàng)目上合作的話,僅僅是一個(gè) SSH 服務(wù)器和裸倉(cāng)庫(kù)就足夠了,記住這點(diǎn)就可以了。
如果設(shè)備較少或者你只想在小型開(kāi)發(fā)團(tuán)隊(duì)里嘗試 Git ,那么一切都很簡(jiǎn)單。架設(shè) Git 服務(wù)最復(fù)雜的地方在于賬戶管理。如果需要倉(cāng)庫(kù)對(duì)特定的用戶可讀,而給另一部分用戶讀寫權(quán)限,那么訪問(wèn)和許可的安排就比較困難。
如果已經(jīng)有了一個(gè)所有開(kāi)發(fā)成員都可以用 SSH 訪問(wèn)的服務(wù)器,架設(shè)第一個(gè)服務(wù)器將變得異常簡(jiǎn)單,幾乎什么都不用做(正如上節(jié)中介紹的那樣)。如果需要對(duì)倉(cāng)庫(kù)進(jìn)行更復(fù)雜的訪問(wèn)控制,只要使用服務(wù)器操作系統(tǒng)的本地文件訪問(wèn)許可機(jī)制就行了。
如果需要團(tuán)隊(duì)里的每個(gè)人都對(duì)倉(cāng)庫(kù)有寫權(quán)限,又不能給每個(gè)人在服務(wù)器上建立賬戶,那么提供 SSH 連接就是唯一的選擇了。我們假設(shè)用來(lái)共享倉(cāng)庫(kù)的服務(wù)器已經(jīng)安裝了 SSH 服務(wù),而且你通過(guò)它訪問(wèn)服務(wù)器。
有好幾個(gè)辦法可以讓團(tuán)隊(duì)的每個(gè)人都有訪問(wèn)權(quán)。第一個(gè)辦法是給每個(gè)人建立一個(gè)賬戶,直截了當(dāng)?shù)赃^(guò)繁瑣。反復(fù)運(yùn)行 adduser
并給所有人設(shè)定臨時(shí)密碼可不是好玩的。
第二個(gè)辦法是在主機(jī)上建立一個(gè) git
賬戶,讓每個(gè)需要寫權(quán)限的人發(fā)送一個(gè) SSH 公鑰,然后將其加入 git
賬戶的 ~/.ssh/authorized_keys
文件。這樣一來(lái),所有人都將通過(guò) git
賬戶訪問(wèn)主機(jī)。這絲毫不會(huì)影響提交的數(shù)據(jù) — 訪問(wèn)主機(jī)用的身份不會(huì)影響提交對(duì)象的提交者信息。
另一個(gè)辦法是讓 SSH 服務(wù)器通過(guò)某個(gè) LDAP 服務(wù),或者其他已經(jīng)設(shè)定好的集中授權(quán)機(jī)制,來(lái)進(jìn)行授權(quán)。只要每個(gè)人都能獲得主機(jī)的 shell 訪問(wèn)權(quán),任何可用的 SSH 授權(quán)機(jī)制都能達(dá)到相同效果。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號(hào)-3|閩公網(wǎng)安備35020302033924號(hào)
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號(hào)
聯(lián)系方式:
更多建議: