使用Gitolite搭建轻量级的Git服务器

转自【http://blog.chinaunix.NET/uid-15174104-id-3843570.html】

使用Gitolite搭建轻量级的Git服务器

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。
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Gogs是一款极易搭建的自助Git服务。Gogs的目标是打造一个最简单、最快速和最轻松的方式搭建自助Git服务。使用Go语言开发使得Gogs能够通过独立的二进制分发,并且支持Go语言支持的所有平台,包括Linux、MacOSX、Windows以及ARM平台。 Gogs功能特性: 支持活动时间线 支持SSH以及HTTP/HTTPS协议 支持SMTP、LDAP和反向代理的用户认证 支持反向代理子路径 支持用户、组织和仓库管理系统 支持添加和删除仓库协作者 支持仓库和组织级别Web钩子(包括Slack集成) 支持仓库Git钩子和部署密钥 支持仓库工单(Issue)、合并请求(Pull Request)、Wiki以及保护分支 支持迁移和镜像仓库以及它的Wiki 支持在线编辑仓库文件和Wiki 支持自定义源的Gravatar和Federated Avatar 支持Jupyter Notebook 支持邮件服务 支持后台管理面板 支持MySQL、PostgreSQL、SQLite3、MSSQL和TiDB(实验性支持)数据库 支持多语言本地化(22种语言) 系统要求: 最低的系统硬件要求为一个廉价的树莓派 如果用于团队项目,建议使用2核CPU及1GB内存 浏览器支持: 请根据Semantic UI查看具体支持的浏览器版本。 官方支持的最小UI尺寸为1024*768,UI不一定会在更小尺寸的设备上被破坏,但我们无法保证且不会修复。 安装部署: 在安装Gogs之前,您需要先安装基本环境。 然后,您可以通过以下5种方式来安装Gogs: 二进制安装 源码安装 包管理安装 采用Docker部署 通过Vagrant安装

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值