1.安裝配置git服務器
安裝git: sudo apt-get install git-core
新加用戶git,該用戶將作為所有代碼倉庫和用戶權限的管理者:
sudo useradd -m git
sudo passwd git
建立一個git倉庫的存儲點: sudo mkdir /home/repo
讓除了git以外的用戶對此目錄無任何權限:
sudo chown git:git /home/repo
sudo chmod 755 /home/repo
PS:此處要把git倉庫repo的屬性設置成755,不然在gitweb中一直無法找到工程
2.安裝配置gitosis
初始化一下服務器的git用戶,這一步其實是為了安裝gitosis做準備。在任何一 臺機器上使用git,第一次必須要初始化一下:
git config –-global user.name “scorpio”
git config –-global user.email “zsw.scorpio@gmail.com”
安裝一下python的setup tool, 這個也是為了gitosis做準備:
sudo apt-get install python-setuptools
獲得gitosis包:
cd /tmp
git clone git://eagain.net/gitosis.git
cd gitosis
sudo python setup.py install
切換到git用戶下:
su git
默認狀態下,gitosis會將git倉庫放在 git用戶的home下,所以我們做一個鏈接到/home/repo
ln -s /home/repo /home/git/repositories
再次返回到默認用戶
$ exit
如果你將作為git服務器的管理員,那么在你的電 腦上生成ssh公鑰:
本地:ssh-keygen -t rsa
將公鑰拷貝到服務器的/tmp下:
本地:scp .ssh/id_rsa.pub git@xxoo.com:/tmp
回到git服務器上
sudo chmod a+r /tmp/id_rsa.pub
讓gitosis運行起來:
sudo -H -u git gitosis-init /tmp/id_rsa.pub
gitosis的有趣之處在于,它通過一個git倉庫來管理配置文件,倉庫就放在了/home/repo/gitosis- admin.git。我們需要為一個文件加上可執行權限:
sudo passwd root/p>
p>su/p>
p>cd repositories/p>
p>cd gitosis-admin.git//p>
p>sudo chmod 755 /home/repo/gitosis-admin.git/hooks/post-update/p>
p>exit
3.在服務器上新建一個測試項目倉庫
我們在服務器上新建一個空的項目倉庫,叫“test”。
切換到git用戶:
su git/p>
p>cd /home/repo/p>
p>mkdir test.git/p>
p>cd test.git/p>
p>git init –bare注:這是在服務器上運行的,是為了初始化一個根級的git倉庫/p>
p>exit
這只是一個空倉庫,空倉庫是不能clone下來的。我們必須先修改一下gitosis-admin.
4.管理gitosis的配置文件
gitosis本身的配置也是通過git來實現的。在你自己的開發機里,把gitosis-admin.git這個倉庫clone下來,就可以以管理員的身份修改配置了。
在你的電腦里:
git clone git@xxoo.com:gitosis-admin.git/p>
p>cd gitosis-admin/
該目錄下的keydir目錄是用來存放所有需要訪問git服務器的用戶的ssh公鑰:
各個用戶按照前面提到的辦法生成各自的ssh公鑰文件后,把所有人的 ssh公鑰文件都拿來,按名字命名一下,比如b.pub, lz.pub等,統統拷貝到keydir下
修改gitosis.conf文件,我的配置大致如下:
[gitosis]/p>
p>[group gitosis-admin]/p>
p>members = zsw.scorpio@gmail.com/p>
p>writable = gitosis-admin
加入新文件、提交并push到git服務器:
git add ./p>
p>git commit -m “add”/p>
p>git push origin master
5.初始化測試項目
好了,現在服務器就搭建完了,并且有一個空的項目test在服務器上。接下來測試一下,空倉庫是不能clone的,以下是在客戶端完成。
mkdir dev/p>
p>cd dev//p>
p>git init/p>
p>echo “/*add something*/” > hello/p>
p>git add ./p>
p>git commit -m “initial version”/p>
p>git remote add origin git@xxoo.com:test.git/p>
p>git push origin master
到此為止test已經有了一個版本了,其他成員只要先clone一下 teamwork倉庫,就可以任意玩了。
git clone git@xxoo.com:test.git/p>
p>cd teamwork/p>
p>vim hello/p>
p>git add ./p>
p>git commit -a “b add”/p>
p>git push origin master/p>
p>exit
6.創建gitweb
sudo apt-get install gitweb
配置 gitweb
默認沒有 css 加載,把 gitweb 要用的靜態文件連接到
cd /var/www//p>
p>sudo ln -s /usr/share/gitweb/* .
修改配置
sudo vim /etc/gitweb.conf
將 $projectroot 改為git倉庫存儲目錄(例如:/home/git/repositories),保存后刷新瀏覽器。
http://xxoo.com/cgi-bin/gitweb.cgi
7. 修改/etc/gitweb.conf 內容
# path to git projects (project>.git)/p>
p>#$projectroot = “/var/cache/git”;/p>
p>$projectroot = “/home/git/repositories”;/p>
p># directory to use for temp files/p>
p>$git_temp = “/tmp”;/p>
p># target of the home link on top of all pages/p>
p>$home_link = $my_uri || “/”;/p>
p># html text to include at home page/p>
p>$home_text = “indextext.html”;/p>
p># file with project list; by default, simply scan the projectroot dir./p>
p>$projects_list = $projectroot;/p>
p># stylesheet to use/p>
p>@stylesheets = (“/gitweb/static/gitweb.css”);/p>
p># javascript code for gitweb/p>
p>$javascript = “gitweb/static/gitweb.js”;/p>
p># logo to use/p>
p>$logo = “/gitweb/static/git-logo.png”;/p>
p># the ‘favicon’/p>
p>$favicon = “/gitweb/static/git-favicon.png”;/p>
p># git-diff-tree(1) options to use for generated patches/p>
p>#@diff_opts = (“-M”);/p>
p>@diff_opts = ();
8.重啟apache
sudo /etc/init.d/apache2 restart