By Harrison Feng
在Git服務管理工具這個領域,主要有三種流行的方案,它們分別是
大名鼎鼎的Android平台就是使用的 Git + Repo + Gerrit。對於個人,中小型企業及一些開源項目而言,如果沒有特殊的要求,其實沒有
必要去架設上面第三種方案Git服務器。Gitolite提供的服務已經足夠用。下面將詳細講解怎么搭建Gitolite服務器。
Gitolite的安裝需要分別在客戶端和服務器端操作。搭建Gitolite的步驟如圖所示。
在Ubuntu12.04 LTS上搭建Gitolite服務器的詳細步驟,假設客戶端和服務器端已經安裝好了Git。如果還沒有安裝Git,請分別在
客戶端和服務器端運行下面的命令安裝Git。
- $ sudo apt-get install git
- $ ssh-keygen -t rsa -C HF
運行命令后,一直按回車鍵直到SSH key生成。
這里注意,為了區分SSH public key,請將SSH public key重命名,最好是用用戶名命名。例如 <user-name>.pub
- $ mv /home/UBUNTUUSERS/hf/.ssh/id_rsa.pub HF.pub
- $ scp HF.pub hf@ubuntu-12.04-LTS:/tmp
- $ sudo adduser \
- > --system \
- > --shell /bin/bash \
- > --gecos 'Git SCM User' \
- > --group \
- > --disabled-password \
- > --home /home/git git
- $ sudo su git
- $ cd $HOME
- $ git clone http://github.com/sitaramc/gitolite
- $ mkdir -p ${HOME}/bin
- $ ${HOME}/gitolite/install -to ${HOME}/bin
- $ ${HOME}/bin/gitolite setup -pk /tmp/HF.pub
其實,到這里,Gitolite已經安裝完成。接下來就是添加Git項目,用戶和設置Git項目的訪問權限了。
但是如果你的服務器對SSH的權限做了限制,例如只有在sshusers用戶組里的用戶才可以SSH到服務器,那么你還需要做一個額外的設置
那就是添加git用戶及以后的Gitolite的用戶到sshusers用戶組。否則,當你克隆Git項目時,你將被提示輸入密碼。如下圖:
- $ git clone git@ubuntu-12.04-LTS:gitolite-admin.git
你可以看到在管理庫里,有兩個目錄, conf/和keydir/,其中conf/下面有個名為gitolite.conf的配置文件。
- conf/gitolite.conf 用於Git項目配置,訪問權限設置。
- keydir/ 用於存儲用戶的SSH public key(公鑰)。
Git項目配置和訪問權限設置請看Gitolite的README.txt文檔。
為了增加Git項目到Gitolite服務器,有兩種方法:
- 修改gitolite.conf
例如,新建一個名為foo的Git項目,首先你需要在conf/gitolite.conf里注冊foo項目。
假設你已經克隆了gitolite-admin.git項目,編輯conf/gitolite.conf,增加下面的內容【3】。然后提交這部分修改,並push到遠程。
- repo foo
- RW+ = @all
- 設置Git項目
現在Git項目foo已經設置好了。用戶可以從服務器上克隆foo了 【4】。
- hf@ubuntu-12.04-LTS:~$ mkdir foo
- hf@ubuntu-12.04-LTS:~$ cd foo
- hf@ubuntu-12.04-LTS:~/foo$ git init
- Initialized empty Git repository in /home/UBUNTUUSERS/hf/foo/.git/
- hf@ubuntu-12.04-LTS:~/foo (master)$ git remote add origin hf@ubuntu-12.04-LTS.git
- hf@ubuntu-12.04-LTS:~/foo (master)$ touch README
- hf@ubuntu-12.04-LTS:~/foo (master)$ git add README
- hf@ubuntu-12.04-LTS:~/foo (master)$ git commit -m "Initial commit"
- [master (root-commit) 997d5d8] Initial commit
- 0 files changed, 0 insertions(+), 0 deletions(-)
- create mode 100644 README
- hf@ubuntu-12.04-LTS:~/foo (master)$ git push origin master:refs/heads/master
- Counting objects: 3, done.
- Writing objects: 100% (3/3), 217 bytes, done.
- Total 3 (delta 0), reused 0 (delta 0)
- To hf@ubuntu-12.04-LTS:foo.git
- * [new branch] master -> master
- hf@ubuntu-12.04-LTS:~$ git clone hf@ubuntu-12.04-LTS:foo.git
- Cloning into 'foo'...
- remote: Counting objects: 3, done.
- remote: Total 3 (delta 0), reused 0 (delta 0)
- Receiving objects: 100% (3/3), done.
如果你有一個已經存在的項目,也想將其添加到Gitolite的服務器里。這很簡單,但是首先你依然需要在gitolite.conf里注冊
這個項目。然后執行下面的操作:如果你有多個branch,那么checkout到那個branch,執行
- cd foo
- git remote rm origin
- git remote add origin hf@ubuntu-12.04-LTS.foo.git
- git push origin master
- git push origin <branch-name>
注:
【1】 如果是企業內部網絡,可能你需要設置HTTP代理,方法如下:
$ export http_proxy=http://proxy.<server-name>.com:<port-number>/
例如: export http_proxy=http://proxy.server.com:8080/
【2】 此步驟僅Gitolite的管理員才有權限執行。
【3】 在這里,我們把foo項目的讀寫權限給了所有的Gitolite用戶,實際的項目中,你
最好不要這樣做。請為不同級別的用戶設置不同的權限。
【4】 由於我的客戶端和服務器是同一台PC,所以這里域名都是ubuntu-12.04-LTS。