搭建git服務(wù)器

遠(yuǎn)程倉(cāng)庫(kù)一節(jié)中,我們講了遠(yuǎn)程倉(cāng)庫(kù)實(shí)際上和本地倉(cāng)庫(kù)沒(méi)啥不同奕坟,純粹為了7x24小時(shí)開(kāi)機(jī)并交換大家的修改。

GitHub就是一個(gè)免費(fèi)托管開(kāi)源代碼的遠(yuǎn)程倉(cāng)庫(kù)。但是對(duì)于某些視源代碼如生命的商業(yè)公司來(lái)說(shuō)蜓氨,既不想公開(kāi)源代碼,又舍不得給GitHub交保護(hù)費(fèi)队伟,那就只能自己搭建一臺(tái)Git服務(wù)器作為私有倉(cāng)庫(kù)使用穴吹。

搭建Git服務(wù)器需要準(zhǔn)備一臺(tái)運(yùn)行Linux的機(jī)器,強(qiáng)烈推薦用Ubuntu或Debian嗜侮,這樣港令,通過(guò)幾條簡(jiǎn)單的apt命令就可以完成安裝代嗤。

假設(shè)你已經(jīng)有sudo權(quán)限的用戶賬號(hào),下面缠借,正式開(kāi)始安裝干毅。

第一步,安裝git:

$ sudoapt-getinstall git

第二步泼返,創(chuàng)建一個(gè)git用戶硝逢,用來(lái)運(yùn)行g(shù)it服務(wù):

$ sudoadduser git

第三步,創(chuàng)建證書(shū)登錄:

收集所有需要登錄的用戶的公鑰绅喉,就是他們自己的id_rsa.pub文件渠鸽,把所有公鑰導(dǎo)入到/home/git/.ssh/authorized_keys文件里,一行一個(gè)柴罐。

第四步徽缚,初始化Git倉(cāng)庫(kù):

先選定一個(gè)目錄作為Git倉(cāng)庫(kù),假定是/srv/sample.git革屠,在/srv目錄下輸入命令:

$ sudogit init --bare sample.git

Git就會(huì)創(chuàng)建一個(gè)裸倉(cāng)庫(kù)凿试,裸倉(cāng)庫(kù)沒(méi)有工作區(qū),因?yàn)榉?wù)器上的Git倉(cāng)庫(kù)純粹是為了共享似芝,所以不讓用戶直接登錄到服務(wù)器上去改工作區(qū)那婉,并且服務(wù)器上的Git倉(cāng)庫(kù)通常都以.git結(jié)尾。然后党瓮,把owner改為git:

$ sudochown -R git:git sample.git

第五步详炬,禁用shell登錄:

出于安全考慮,第二步創(chuàng)建的git用戶不允許登錄shell寞奸,這可以通過(guò)編輯/etc/passwd文件完成呛谜。找到類似下面的一行:

git:x:1001:1001:,,,:/home/git:/bin/bash

改為:

git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell

這樣,git用戶可以正常通過(guò)ssh使用git枪萄,但無(wú)法登錄shell隐岛,因?yàn)槲覀優(yōu)間it用戶指定的git-shell每次一登錄就自動(dòng)退出。

第六步呻引,克隆遠(yuǎn)程倉(cāng)庫(kù):

現(xiàn)在礼仗,可以通過(guò)git clone命令克隆遠(yuǎn)程倉(cāng)庫(kù)了,在各自的電腦上運(yùn)行:

$git clone git@server:/srv/sample.gitCloninginto'sample'...warning:Youappear to have cloned an empty repository.

剩下的推送就簡(jiǎn)單了逻悠。

管理公鑰

如果團(tuán)隊(duì)很小元践,把每個(gè)人的公鑰收集起來(lái)放到服務(wù)器的/home/git/.ssh/authorized_keys文件里就是可行的。如果團(tuán)隊(duì)有幾百號(hào)人童谒,就沒(méi)法這么玩了单旁,這時(shí),可以用Gitosis來(lái)管理公鑰饥伊。

這里我們不介紹怎么玩Gitosis了象浑,幾百號(hào)人的團(tuán)隊(duì)基本都在500強(qiáng)了蔫饰,相信找個(gè)高水平的Linux管理員問(wèn)題不大。

管理權(quán)限

有很多不但視源代碼如生命愉豺,而且視員工為竊賊的公司篓吁,會(huì)在版本控制系統(tǒng)里設(shè)置一套完善的權(quán)限控制,每個(gè)人是否有讀寫(xiě)權(quán)限會(huì)精確到每個(gè)分支甚至每個(gè)目錄下蚪拦。因?yàn)镚it是為L(zhǎng)inux源代碼托管而開(kāi)發(fā)的杖剪,所以Git也繼承了開(kāi)源社區(qū)的精神,不支持權(quán)限控制驰贷。不過(guò)盛嘿,因?yàn)镚it支持鉤子(hook),所以括袒,可以在服務(wù)器端編寫(xiě)一系列腳本來(lái)控制提交等操作次兆,達(dá)到權(quán)限控制的目的。Gitolite就是這個(gè)工具锹锰。

這里我們也不介紹Gitolite了芥炭,不要把有限的生命浪費(fèi)到權(quán)限斗爭(zhēng)中。

小結(jié)

搭建Git服務(wù)器非常簡(jiǎn)單城须,通常10分鐘即可完成蚤认;

要方便管理公鑰米苹,用Gitosis糕伐;

要像SVN那樣變態(tài)地控制權(quán)限,用Gitolite蘸嘶。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末良瞧,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子训唱,更是在濱河造成了極大的恐慌褥蚯,老刑警劉巖,帶你破解...
    沈念sama閱讀 212,686評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件况增,死亡現(xiàn)場(chǎng)離奇詭異赞庶,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)澳骤,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,668評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)歧强,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人为肮,你說(shuō)我怎么就攤上這事摊册。” “怎么了颊艳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 158,160評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵茅特,是天一觀的道長(zhǎng)忘分。 經(jīng)常有香客問(wèn)我,道長(zhǎng)白修,這世上最難降的妖魔是什么妒峦? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,736評(píng)論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮兵睛,結(jié)果婚禮上舟山,老公的妹妹穿的比我還像新娘。我一直安慰自己卤恳,他們只是感情好累盗,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,847評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著突琳,像睡著了一般若债。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上拆融,一...
    開(kāi)封第一講書(shū)人閱讀 50,043評(píng)論 1 291
  • 那天蠢琳,我揣著相機(jī)與錄音,去河邊找鬼镜豹。 笑死傲须,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的趟脂。 我是一名探鬼主播泰讽,決...
    沈念sama閱讀 39,129評(píng)論 3 410
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼昔期!你這毒婦竟也來(lái)了已卸?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,872評(píng)論 0 268
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤硼一,失蹤者是張志新(化名)和其女友劉穎累澡,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體般贼,經(jīng)...
    沈念sama閱讀 44,318評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡愧哟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,645評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了哼蛆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蕊梧。...
    茶點(diǎn)故事閱讀 38,777評(píng)論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖人芽,靈堂內(nèi)的尸體忽然破棺而出望几,到底是詐尸還是另有隱情,我是刑警寧澤萤厅,帶...
    沈念sama閱讀 34,470評(píng)論 4 333
  • 正文 年R本政府宣布橄抹,位于F島的核電站靴迫,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏楼誓。R本人自食惡果不足惜玉锌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,126評(píng)論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望疟羹。 院中可真熱鬧主守,春花似錦、人聲如沸榄融。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,861評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)愧杯。三九已至涎才,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間力九,已是汗流浹背耍铜。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,095評(píng)論 1 267
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留跌前,地道東北人棕兼。 一個(gè)月前我還...
    沈念sama閱讀 46,589評(píng)論 2 362
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像抵乓,于是被迫代替她去往敵國(guó)和親伴挚。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,687評(píng)論 2 351

推薦閱讀更多精彩內(nèi)容