By Harrison Feng

在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。

  1. $ sudo apt-get install git
  • 生成SSH key(客户端)

  1. $ ssh-keygen -t rsa -C HF


运行命令后,一直按回车键直到SSH key生成。

  • 将生成的SSH public key拷贝到服务器(客户端)

这里注意,为了区分SSH public key,请将SSH public key重命名,最好是用用户名命名。例如 <user-name>.pub

  1. $ mv /home/UBUNTUUSERS/hf/.ssh/id_rsa.pub HF.pub
  2. $ scp HF.pub hf@ubuntu-12.04-LTS:/tmp

  • 创建Git用户(服务器端)

  1. $ sudo adduser \
  2. > --system \
  3. > --shell /bin/bash \
  4. > --gecos 'Git SCM User' \
  5. > --group \
  6. > --disabled-password \
  7. > --home /home/git git

  • 下载Gitolite源码(服务器端)【1】

  1. $ sudo su git
  2. $ cd $HOME
  3. $ git clone http://github.com/sitaramc/gitolite

  • 安装Gitolite(服务器端)

  1. $ mkdir -p ${HOME}/bin
  2. $ ${HOME}/gitolite/install -to ${HOME}/bin
  • 设置SSH public key(服务器端)

  1. $ ${HOME}/bin/gitolite setup -pk /tmp/HF.pub


其实,到这里,Gitolite已经安装完成。接下来就是添加Git项目,用户和设置Git项目的访问权限了。
但是如果你的服务器对SSH的权限做了限制,例如只有在sshusers用户组里的用户才可以SSH到服务器,那么你还需要做一个额外的设置
那就是添加git用户及以后的Gitolite的用户到sshusers用户组。否则,当你克隆Git项目时,你将被提示输入密码。如下图:

  • 添加git用户sshusers用户组(服务器端)

  • 克隆Gitolite管理库(客户端)

  1. $ 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】

  1. repo foo
  2. RW+ = @all

然后提交这部分修改,并push到远程。

  • 设置Git项目
  1. hf@ubuntu-12.04-LTS:~$ mkdir foo
  2. hf@ubuntu-12.04-LTS:~$ cd foo
  3. hf@ubuntu-12.04-LTS:~/foo$ git init
  4. Initialized empty Git repository in /home/UBUNTUUSERS/hf/foo/.git/
  5. hf@ubuntu-12.04-LTS:~/foo (master)$ git remote add origin hf@ubuntu-12.04-LTS.git
  6. hf@ubuntu-12.04-LTS:~/foo (master)$ touch README
  7. hf@ubuntu-12.04-LTS:~/foo (master)$ git add README
  8. hf@ubuntu-12.04-LTS:~/foo (master)$ git commit -m "Initial commit"
  9. [master (root-commit) 997d5d8] Initial commit
  10. 0 files changed, 0 insertions(+), 0 deletions(-)
  11. create mode 100644 README
  12. hf@ubuntu-12.04-LTS:~/foo (master)$ git push origin master:refs/heads/master
  13. Counting objects: 3, done.
  14. Writing objects: 100% (3/3), 217 bytes, done.
  15. Total 3 (delta 0), reused 0 (delta 0)
  16. To hf@ubuntu-12.04-LTS:foo.git
  17. * [new branch] master -> master

现在Git项目foo已经设置好了。用户可以从服务器上克隆foo了【4】

  1. hf@ubuntu-12.04-LTS:~$ git clone hf@ubuntu-12.04-LTS:foo.git
  2. Cloning into 'foo'...
  3. remote: Counting objects: 3, done.
  4. remote: Total 3 (delta 0), reused 0 (delta 0)
  5. Receiving objects: 100% (3/3), done.
  • 添加一个存在的Git项目

如果你有一个已经存在的项目,也想将其添加到Gitolite的服务器里。这很简单,但是首先你依然需要在gitolite.conf里注册
这个项目。然后执行下面的操作:

  1. cd foo
  2. git remote rm origin
  3. git remote add origin hf@ubuntu-12.04-LTS.foo.git
  4. git push origin master

如果你有多个branch,那么checkout到那个branch,执行

  1. 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。

使用Gitolite搭建轻量级的Git服务器的更多相关文章

  1. Linux系统搭建并管理Git服务器

    搭建Git服务器 GitHub就是一个免费托管开源代码的远程仓库.但是对于某些视源代码如生命的商业公司来说,既不想公开源代码,又舍不得给GitHub交保护费,那就只能自己搭建一台Git服务器作为私有仓 ...

  2. 搭建自己的Git服务器

    前言: GitHub是一个免费托管开源代码的远程仓库,使用起来即方便又安全,但在国内有时访问巨慢,原因你懂得.还有一些公司和个人视源码如生命,既不想开源代码又不想给Github交保护费.这时搭建一个自 ...

  3. 在阿里云上搭建自己的git服务器

    这篇文章我就来介绍一下如何在一台全裸的阿里云主机上搭建自己的git服务器. 1. 安装git 首先安装git,一般而言,现在的服务器已经内置了git安装包,我们只需要执行简单的安装命令即可安装.比如: ...

  4. Windows平台下搭建自己的Git服务器

    该文章转自:http://www.codeceo.com/article/windows-git-server.html Gitblit 是一个纯 Java 库用来管理.查看和处理 Git 资料库,相 ...

  5. 阿里云Linux CentOS 7 Docker部署使用gogs搭建自己的git服务器

    一.前言 Git是目前优秀和流行的源代码管理工具.而GitHub是一个面向开源及私有软件项目的托管云平台,但开源免费,私有收费.而公司出于商业化等目的需要搭建自己的源代码托管服务器.通过网上了解Gog ...

  6. 搭建自己的git服务器--gogs

    //@desn:搭建自己的git服务器--gogs //@desn:码字不宜,转载请注明出处 //@author:张慧源  <turing_zhy@163.com> //@date:201 ...

  7. 阿里云CentOS7.3搭建多用户私有git服务器(从安装git开始)

    起因 自己会有练手的不敢公开的项目,就自己搭建个服务器放自己的渣代码了. 在经历了连不上服务器.没有访问权限.没法提交以后,我打通了任督二脉. 我这个git服务器适合条件:1.就那么几个人小项目,不是 ...

  8. 在CentOS下搭建自己的Git服务器

    首先需要装好CentOS系统,作为测试,你可以选择装在虚拟机上,这样比较方便.这步默认你会,就不讲了.有了CentOS,那么如何搭建Git服务器呢?1.首先需要安装Git,可以使用yum源在线安装: ...

  9. 用gogs轻松搭建个人的git服务器

    因为公司和家里电脑里面有些项目需做版本控制或者说共享吧,就想搭个自己的git服务器:原本想用gitlab,不过我服务器配置比较差,查了一下,看到gogs,眼前一亮: Gogs 的目标是打造一个最简单. ...

随机推荐

  1. 为OpenEdx中lms注册模块扩展字段

    最近遇到需求,需要扩展注册的字段,例如新增手机mobile字段 1.打开register.html文件   路径为\edxapp\edx-platform\lms\templates\register ...

  2. 十天学会<div+css>横向导航菜单和纵向导航菜单

    纵向导航菜单及二级弹出菜单 纵向导航菜单:一级菜单 <head><style type="text/css">body { font-family: Ver ...

  3. Sublime Text 2 配置(转载)

    转载 自 Sublime Text 2 的详细配置(C++) 想起暑假在公司偷偷写题,用不惯vs ,配sublime 又一直编译不了...每次用codeblocks 眼泪掉下来www 下载sublim ...

  4. git pull 和本地文件冲突问题解决

    具体方法如下 git pull origin 分支 //出现错误 git stash  缓存起来 git pull origin 分支 git stash pop //还原 git stash cle ...

  5. JS/jquery获取iframe内部元素和ifame中获取外部元素精华

    1.从外部获取iframe内部元素方法: js : window.frames['frame'].document.getElementById("imglist");   //f ...

  6. Android App的签名打包三步骤

    1.签名的意义 为了保证每个应用程序开发商合法ID,防止部分开放商可能通过使用相同的Package Name来混淆替换已经安装的程序,我们需要对我们发布的APK文件进行唯一签名,保证我们每次发布的版本 ...

  7. SetProcessAffinityMask的问题

    BOOL WINAPI SetProcessAffinityMask( _In_ HANDLE hProcess, _In_ DWORD_PTR dwProcessAffinityMask );//M ...

  8. apache和nginx

    虽然nginx使用较少 还是写写文章,记录下 nginx是异步非阻塞,apache是阻塞的. apache动态页面比nginx好. 由于nginx的高并发性(使用epoll模型),所以出来静态页面性能 ...

  9. Linux 内核常见宏定义

    我们在阅读Linux内核是,常见到这些宏 __init, __initdata, __initfunc(), asmlinkage, ENTRY(), FASTCALL()等等.它们定义在 /incl ...

  10. 动态加载JS脚本

    建立dynamic.js文件,表示动态加载的js文件,里面的内容为: function dynamicJS() { alert("加载完毕"); } 如下方法中的html页面和dy ...