centos7 安裝 gitolite (git服務器)

gitolite簡介

輕量級git服務器程序,解決了git權限管理的問題。(git是一個分佈式版本控制系統,就是說每一個人做爲客戶端的同時又是服務器)
項目GitHub地址:https://github.com/sitaramc/gitolite
項目官方文檔:http://gitolite.com/gitolite/
當前環境:centos 7android

安裝前準備

  • 在客戶端機器安裝git,並生成祕鑰
    各操做系統安裝方法均很簡單,請自行安裝。
    使用git安裝目錄下的 usr/bin/ssh-keygen生成rsa祕鑰ios

    ssh-keygen -t rsa

    而後一路回車到結束。(生成祕鑰默認在當前用戶目錄的.ssh目錄下,下面要用)nginx

  • 安裝沒有安裝的依賴包c++

    yum install -y gcc gcc-c++ pcre pcre-devel zlib zlib-devel openssl openssl-devel perl* git

    須要注意:gitolite對以上軟件版本有必定的要求,若是報錯,升級軟件便可。git

    yum update -y <軟件名>
  • 建立用戶github

    useradd git passwd git
    若是已有用戶,請確認
    1. ~/.ssh/authorized_keys文件是空的或者不存在
    2. 客戶機ssh-keygen生成的id_rsa.pub公鑰已經拷貝到:~/YourName.pub ,改爲本身的名字,爲了多人協做時便於區分,並非硬性規定

開始安裝

su git <!-- 切換到git用戶 --> git clone git://github.com/sitaramc/gitolite mkdir -p ~/bin <!-- 必定要建立bin文件夾 --> ~/gitolite/install -to ~/bin ~/bin/gitolite setup -pk YourName.pub <!-- 生成下面所要用的管理庫gitolite-admin和測試用庫testing -->

安裝完成web

添加用戶和倉庫

下載管理倉庫sql

git clone git@host:gitolite-admin.git

打開看到兩個文件夾:
conf:存放配置文件(受權文件)
keyDir:存放全部客戶端用戶的公鑰django

打開conf/gitolite.conf 配置以下:centos

@webgroup = zhangsan lisi @androidgroup = lisi @iosgroup = wangwu <!-- 設置管理員的地方 --> repo gitolite-admin RW+ = lisi <!-- 能夠用來學習使用 --> repo testing RW+ = @all repo web RW+ = @webgroup R = fengshuang repo android RW+ = @androidgroup repo ios RW+ = @iosgroup

表示新建三個分組:@webgroup、@androidgroup、@iosgroup,新建三個倉庫:web、android、ios,RW分別表明讀寫,能夠經過人所屬組給人賦權,也能夠直接給人賦權,組前記得加@
將以上配置人間中的人的公鑰複製到keyDir文件夾
而後回到倉庫根目錄gitolite-admin下,使用如下命令提交修改:

git add .
git commit -m "add users and repos" git push

【注意】:開發人員能夠git clone倉庫的前提是在這個配置文件中進行了受權提交,而且其公鑰已經交由管理員提交到keyDir目錄中。
簡單的權限管理及這麼多,基本上夠項目使用,更加負責的權限配置,請參閱官方文檔。http://gitolite.com/gitolite/

開發人員下載倉庫

這裏以張三下載web倉庫爲例

git clone git@host:web.git <!-- 別忘了後面的.git -->
相關文章
相關標籤/搜索