gitolite服务器搭建
现在Git已经是铺天盖地了,如果再不用尝试真的是要out了。于是决定在新的项目中应用Git。奋战了一个下午加另外2个小时,终于搞定。发现Git真的真的是很简单,超出我的意料。可是既然简单,为什么又是艰难的呢?因为从之前CVS、SVN的思路和使用习惯转过来的确有点费劲。
问题一:Git的服务器版本是什么样的?如何安装?
SVN是有一个svnserver,可以通过yum或者apt-get直接安装,那么Git的服务器版本是什么呢?通过yum search git,只发现了gitolite和gitosis好像和Server有点关系,而gitosis现在已经逐渐被gitolite所取代了。在Github上找到了gitolite的安装说明:http://sitaramc.github.com/gitolite/install.html,简单的不可思议,做了一遍后发现才发现的确是够用了,一句废话没有。
在进行安装gitolite之前,需要安装git
- # yum -y install git
在服务器上安装gitolite的过程是:
1. 以root身份登录,新建一个git用户,这个用户的主目录会用来存放Git Repository。 这个用户名并非一定要叫git,可以任意指定,只不过git是比较常用的,一看就知道这个账户的作用。
- # useradd -d /home/git git
- # passwd git
2. 以git身份登录服务器,安装gitolite。
- $ git clone https://github.com/sitaramc/gitolite
上面是先从Github获取gitolite,地址中的中https也可以替换成http或者git。 执行下面的命令完成安装:
- $ gitolite/install -ln
至此安装就告一段落了,接下来就是配置了。
问题二、如何配置gitolite?
之前在使用SVN时,为了通过HTTP访问,需要对Apache进行配置。那么gitolite是否也需要进行配置呢?答案当然是肯定的。
前提是要先在管理员(以后负责维护Git的人员)上产生ssh public key,我是在Win7上有putty产生的,命名为kmeng.pub,上传到服务器上git的home目录下。然后执行下面命令:
- $ gitolite setup -pk kmeng.pub
open log failed: No such file or directory
die kmeng.pub must have exactly one line
- $ ssh-keygen -i -f kmeng_o.pub > kmeng.pub
- $ gitolite setup -pk kmeng.pub
命令执行完成后就会产生在/home/git目中在产生repositories目录。kmeng就作为管理员的名字了,也是git repository的第一个用户。
到现在配置也完成了,下面就是用法了。
问题三、既然安装配置都完成了,应该怎么样新建一个项目呢?
这个真的是有点出乎我的意料。Gitolite吧对服务器的维护也采用了普通的repository方式。首先在管理员的本地电脑上,克隆(相当于SVN的checkout)一份gitolite-admin项目:
- git clone git@192.168.0.100:gitolite-admin
在本地就会签出一个gitolite-admin目录,其中包含了conf和keydir两个文件夹,conf中就是存放用户对不同repository的访问权限的配置,而keydir中就是用户的public key,现在里面就只包含了kmeng.pub.
新建一个repository的方式实在出乎意料。首先编辑conf中的gitolite.conf,修改为:
- repo gitolite-admin myapp
- RW+ = kmeng
- repo testing
- RW+ = @all
其中的myapp就是新增加的,然后执行git的commit和push命令就完成了新repository的新建。
- $ git commit -a
- $ git push
再登陆到服务器上,查看/home/git/repositories,发现里面对了一个myapp.git的目录。
以后就只用Git了,真是太简单了。