在git服务管理工具这个领域,主要有三种流行的方案,它们分别是
gitosis– 轻量级, 开源项目,使用ssh公钥认证,只能做到库级的权限控制。目前项目已经停止开发,不再维护。
gitolite– 轻量级,开源项目,使用ssh公钥认证,能做到分支级的权限控制。
git repo gerrit– 超级重量级,集版本控制,库管理和代码审核为一身。可管理大型及超大型项目。
大名鼎鼎的android平台就是使用的 git repo gerrit。对于个人,中小型企业及一些开源项目而言,如果没有特殊的要求,其实没有
必要去架设上面第三种方案git服务器。gitolite提供的服务已经足够用。下面将详细讲解怎么搭建gitolite服务器。
安装gitolite
gitolite的安装需要分别在客户端和服务器端操作。搭建gitolite的步骤如图所示
在ubuntu12.04 lts上搭建gitolite服务器的详细步骤,假设客户端和服务器端已经安装好了git。如果还没有安装git,请分别在
客户端和服务器端运行下面的命令安装git。
$ sudo apt-get install git
生成ssh key(客户端)
$ ssh-keygen -t rsa -c hf
运行命令后,一直按回车键直到ssh key生成。
将生成的ssh public key拷贝到服务器(客户端)
这里注意,为了区分ssh public key,请将ssh public key重命名,最好是用用户名命名。例如.pub
$ mv /home/ubuntuusers/hf/.ssh/id_rsa.pub hf.pub
$ scp hf.pub hf@ubuntu-12.04-lts:/tmp
创建git用户(服务器端)
$ sudo adduser
> –system
> –shell /bin/bash
> –gecos \\\’git scm user\\\’
> –group
> –disabled-password
> –home /home/git git
下载gitolite源码(服务器端)【1】
$ sudo su git
$ cd $home
$ git clone http://github.com/sitaramc/gitolite
安装gitolite(服务器端)
$ mkdir -p ${home}/bin
$ ${home}/gitolite/install -to ${home}/bin
设置ssh public key(服务器端)
$ ${home}/bin/gitolite setup -pk /tmp/hf.pub
其实,到这里,gitolite已经安装完成。接下来就是添加git项目,用户和设置git项目的访问权限了。
但是如果你的服务器对ssh的权限做了限制,例如只有在sshusers用户组里的用户才可以ssh到服务器,那么你还需要做一个额外的设置
那就是添加git用户及以后的gitolite的用户到sshusers用户组。否则,当你克隆git项目时,你将被提示输入密码。如下图:
添加git用户sshusers用户组(服务器端)
克隆gitolite管理库(客户端)
$ 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项目(客户端)【2】
为了增加git项目到gitolite服务器,有两种方法:
添加一个新的git项目
修改gitolite.conf
例如,新建一个名为foo的git项目,首先你需要在conf/gitolite.conf里注册foo项目。
假设你已经克隆了gitolite-admin.git项目,编辑conf/gitolite.conf,增加下面的内容【3】。
repo foo
rw = @all
然后提交这部分修改,并push到远程。
设置git项目
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
现在git项目foo已经设置好了。用户可以从服务器上克隆foo了 【4】。
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.
添加一个存在的git项目
如果你有一个已经存在的项目,也想将其添加到gitolite的服务器里。这很简单,但是首先你依然需要在gitolite.conf里注册
这个项目。然后执行下面的操作:
cd foo
git remote rm origin
git remote add origin hf@ubuntu-12.04-lts.foo.git
git push origin master
如果你有多个branch,那么checkout到那个branch,执行
git push origin
注:
【1】 如果是企业内部网络,可能你需要设置http代理,方法如下:
$ export http_proxy=http://proxy..com:/
例如: export http_proxy=http://proxy.server.com:8080/
【2】 此步骤仅gitolite的管理员才有权限执行。
【3】 在这里,我们把foo项目的读写权限给了所有的gitolite用户,实际的项目中,你
最好不要这样做。请为不同级别的用户设置不同的权限。
【4】 由于我的客户端和服务器是同一台pc,所以这里域名都是ubuntu-12.04-lts。
云服务器怎么保障安全的如何做网站的策划和推广双显卡电脑开机黑屏停顿一分钟后才能进入系统如何解决游戏在阿里云服务器多少钱新手查看域名值多少钱的方法介绍刚学云服务器买多大的深圳云服务器租用哪里好手机短信提示我域名到期-域名及账户问题